JVM內存區域劃分Eden Space、Survivor Space、Tenured Gen,Perm Gen解釋

jvm區域整體分兩類,heap區和非heap區。heap區又分:Eden Space(伊甸園)、Survivor Space(倖存者區)、Tenured Gen(老年代-養老區)。 非heap區又分:Code Cache(代碼緩存區)、Perm Gen(永久代)、Jvm Stack(java虛擬機棧)、Local Method Statck(本地方法棧)。html

HotSpot虛擬機GC算法採用分代收集算法:java

一、一我的(對象)出來(new 出來)後會在Eden Space(伊甸園)無憂無慮的生活,直到GC到來打破了他們平靜的生活。GC會逐一問清楚每一個對象的狀況,有沒有錢(此對象的引用)啊,由於GC想賺錢呀,有錢的才能夠敲詐嘛。而後富人就會進入Survivor Space(倖存者區),窮人的就直接kill掉。算法

二、並非進入Survivor Space(倖存者區)後就保證人身是安全的,但至少能夠活段時間。GC會按期(能夠自定義)會對這些人進行敲詐,億萬富翁每次都給錢,GC很滿意,就讓其進入了Genured Gen(養老區)。萬元戶經不住幾回敲詐就沒錢了,GC看沒有啥價值啦,就直接kill掉了。緩存

三、進入到養老區的人基本就能夠保證人身安全啦,可是億萬富豪有的也會揮霍成窮光蛋,只要錢沒了,GC仍是kill掉。安全

分區的目的:新生區因爲對象產生的比較多而且大都是朝生夕滅的,因此直接採用標記-清理算法。而養老區生命力很強,則採用複製算法,針對不一樣狀況使用不一樣算法。jvm

非heap區域中Perm Gen中放着類、方法的定義,jvm Stack區域放着方法參數、局域變量等的引用,方法執行順序按照棧的先入後出方式。spa

以上轉自:http://lhc1986.iteye.com/blog/1421832線程

如下轉自:http://www.cnblogs.com/xhr8334/archive/2011/12/01/2270994.htmlcode

GC工做機制

SUN的jvm內存池被劃分爲如下幾個部分:htm

Eden Space (heap)

內存最初從這個線程池分配給大部分對象。

 

Survivor Space (heap)

用於保存在eden space內存池中通過垃圾回收後沒有被回收的對象。

 

Tenured Generation (heap)

用於保持已經在survivor space內存池中存在了一段時間的對象。

 

Permanent Generation (non-heap)

保存虛擬機本身的靜態(reflective)數據,例如類(class)和方法(method)對象。Java虛擬機共享這些類數據。這個區域被分割爲只讀的和只寫的。

 

Code Cache (non-heap)

HotSpot Java虛擬機包括一個用於編譯和保存本地代碼(native code)的內存,叫作「代碼緩存區」(code cache)。

 

簡單來說,jvm的內存回收過程是這樣的:

對象在Eden Space建立,當Eden Space滿了的時候,gc就把全部在Eden Space中的對象掃描一次,把全部有效的對象複製到第一個Survivor Space,同時把無效的對象所佔用的空間釋放。當Eden Space再次變滿了的時候,就啓動移動程序把Eden Space中有效的對象複製到第二個Survivor Space,同時,也將第一個Survivor Space中的有效對象複製到第二個Survivor Space。若是填充到第二個Survivor Space中的有效對象被第一個Survivor Space或Eden Space中的對象引用,那麼這些對象就是長期存在的,此時這些對象將被複制到Permanent Generation。

若垃圾收集器依據這種小幅度的調整收集不能騰出足夠的空間,就會運行Full GC,此時jvm gc中止全部在堆中運行的線程並執行清除動做。

相關文章
相關標籤/搜索