91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JVM中怎么解析JVM分代垃圾回收策略

發布時間:2021-10-23 16:54:46 來源:億速云 閱讀:91 作者:柒染 欄目:編程語言

這篇文章將為大家詳細講解有關JVM中怎么解析JVM分代垃圾回收策略,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

由于不同對象的生命周期不一樣,因此在JVM的垃圾回收策略中有分代這一策略。

JVM分代垃圾回收策略的基礎概念

為什么要分代

JVM分代垃圾回收策略,是基于這樣一個事實:不同的對象的生命周期是不一樣的。因此,不同生命周期的對象可以采取不同的收集方式,以便提高回收效率。

在Java程序運行的過程中,會產生大量的對象,其中有些對象是與業務信息相關,比如Http請求中的Session對象、線程、Socket連接,這類對象跟業務直接掛鉤,因此生命周期比較長。但是還有一些對象,主要是程序運行過程中生成的臨時變量,這些對象生命周期會比較短,比如:String對象,由于其不變類的特性,系統會產生大量的這些對象,有些對象甚至只用一次即可回收。

試想,在不進行對象存活時間區分的情況下,每次垃圾回收都是對整個堆空間進行回收,花費時間相對會長,同時,因為每次回收都需要遍歷所有存活對象,但實際上,對于生命周期長的對象而言,這種遍歷是沒有效果的,因為可能進行了很多次遍歷,但是他們依舊存在。因此,分代垃圾回收采用分治的思想,進行代的劃分,把不同生命周期的對象放在不同代上,不同代上采用最適合它的垃圾回收方式進行回收。

如何分代

如圖所示:

JVM中怎么解析JVM分代垃圾回收策略


虛擬機中的共劃分為三個代:年輕代(YoungGeneration)、年老點(OldGeneration)和持久代(PermanentGeneration)。其中持久代主要存放的是Java類的類信息,與垃圾收集要收集的Java對象關系不大。年輕代和年老代的劃分是對垃圾收集影響比較大的。

       年輕代:

所有新生成的對象首先都是放在年輕代的。年輕代的目標就是盡可能快速的收集掉那些生命周期短的對象。年輕代分三個區。一個Eden區,兩個Survivor區(一般而言)。大部分對象在Eden區中生成。當Eden區滿時,還存活的對象將被復制到Survivor區(兩個中的一個),當這個Survivor區滿時,此區的存活對象將被復制到另外一個Survivor區,當這個Survivor去也滿了的時候,從***個Survivor區復制過來的并且此時還存活的對象,將被復制“年老區(Tenured)”。需要注意,Survivor的兩個區是對稱的,沒先后關系,所以同一個區中可能同時存在從Eden復制過來對象,和從前一個Survivor復制過來的對象,而復制到年老區的只有從***個Survivor去過來的對象。而且,Survivor區總有一個是空的。同時,根據程序需要,Survivor區是可以配置為多個的(多于兩個),這樣可以增加對象在年輕代中的存在時間,減少被放到年老代的可能。

年老代:

在年輕代中經歷了N次垃圾回收后仍然存活的對象,就會被放到年老代中。因此,可以認為年老代中存放的都是一些生命周期較長的對象。

持久代:

用于存放靜態文件,如今Java類、方法等。持久代對垃圾回收沒有顯著影響,但是有些應用可能動態生成或者調用一些class,例如Hibernate等,在這種時候需要設置一個比較大的持久代空間來存放這些運行過程中新增的類。持久代大小通過-XX:MaxPermSize=進行設置。

什么情況下觸發JVM分代垃圾回收

由于對象進行了分代處理,因此垃圾回收區域、時間也不一樣。GC有兩種類型:ScavengeGC和FullGC。

ScavengeGC

一般情況下,當新對象生成,并且在Eden申請空間失敗時,就會觸發ScavengeGC,對Eden區域進行GC,清除非存活對象,并且把尚且存活的對象移動到Survivor區。然后整理Survivor的兩個區。這種方式的GC是對年輕代的Eden區進行,不會影響到年老代。因為大部分對象都是從Eden區開始的,同時Eden區不會分配的很大,所以Eden區的GC會頻繁進行。因而,一般在這里需要使用速度快、效率高的算法,使Eden去能盡快空閑出來。

FullGC

對整個堆進行整理,包括Young、Tenured和Perm。FullGC因為需要對整個對進行回收,所以比ScavengeGC要慢,因此應該盡可能減少FullGC的次數。在對JVM調優的過程中,很大一部分工作就是對于FullGC的調節。有如下原因可能導致FullGC:

◆年老代(Tenured)被寫滿

◆持久代(Perm)被寫滿

◆System.gc()被顯示調用

◆上一次GC之后Heap的各域分配策略動態變化

關于JVM中怎么解析JVM分代垃圾回收策略就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

jvm
AI

日照市| 钦州市| 安新县| 驻马店市| 礼泉县| 扶风县| 日喀则市| 铜川市| 安岳县| 万全县| 霸州市| 万荣县| 通榆县| 永济市| 项城市| 本溪市| 巫溪县| 海原县| 泗阳县| 德昌县| 望都县| 教育| 瑞金市| 泸溪县| 吉隆县| 乐都县| 绥中县| 出国| 辛集市| 奈曼旗| 肥乡县| 万荣县| 若羌县| 平武县| 苍山县| 屯留县| 麻江县| 正镶白旗| 汉沽区| 菏泽市| 县级市|