java——jvm堆

對於大多數應用來說,Java 堆(Java Heap)是Java 虛擬機所管理的內存中最大的

一塊。Java 堆是被所有線程共享的一塊內存區域,在虛擬機啓動時創建。此內存區域的

唯一目的就是存放對象實例,幾乎所有的對象實例都在這裏分配內存。這一點在Java 虛

擬機規範中的描述是:所有的對象實例以及數組都要在堆上分配①,但是隨着JIT 編譯器

的發展與逃逸分析技術的逐漸成熟,棧上分配、標量替換②優化技術將會導致一些微妙

的變化發生,所有的對象都分配在堆上也漸漸變得不是那麼“絕對”了。

Java 堆是垃圾收集器管理的主要區域,因此很多時候也被稱做“GC 堆”(Garbage

Collected Heap,幸好國內沒翻譯成“垃圾堆”)。如果從內存回收的角度看,由於現在

收集器基本都是採用的分代收集算法,所以Java 堆中還可以細分爲:新生代和老年代;

再細緻一點的有Eden 空間、From Survivor 空間、To Survivor 空間等。如果從內存分配

的角度看,線程共享的Java 堆中可能劃分出多個線程私有的分配緩衝區(Thread Local

Allocation Buffer,TLAB)。不過,無論如何劃分,都與存放內容無關,無論哪個區域,

存儲的都仍然是對象實例,進一步劃分的目的是爲了更好地回收內存,或者更快地分配

內存。在本章中,我們僅僅針對內存區域的作用進行討論,Java 堆中的上述各個區域的

分配和回收等細節將會是下一章的主題。

根據Java 虛擬機規範的規定,Java 堆可以處於物理上不連續的內存空間中,只要

邏輯上是連續的即可,就像我們的磁盤空間一樣。在實現時,既可以實現成固定大小

的,也可以是可擴展的,不過當前主流的虛擬機都是按照可擴展來實現的(通過-Xmx

和-Xms 控制)。如果在堆中沒有內存完成實例分配,並且堆也無法再擴展時,將會拋出

OutOfMemoryError 異常。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章