十年網站開發(fā)經驗 + 多家企業(yè)客戶 + 靠譜的建站團隊
量身定制 + 運營維護+專業(yè)推廣+無憂售后,網站問題一站解決
在Java8和以后版本中JVM的內存結構慢慢發(fā)生了變化。作為面試官如果你還不知道,那么面試過程中是不是有些露怯?作為面試者,如果知曉這些變化,又將成為面試中的亮點。
如果在網絡上搜索JVM內存結構,90%的可能會搜到Java7及以前的內存圖,本篇文章將會對JVM內存結構再次細化,深入理解Java8之后的內部變化?,F(xiàn)在意×××”的好處了吧。在這里可以不斷的刷新你的知識和認知。
來看一下JVM中的內存結構圖。
為了更細化的講解,我們將該圖進行進一步的優(yōu)化調整。針對java7及以前版本的細化。
看出變化了嗎?堆和方法區(qū)連在了一起,但這并不能說堆和方法區(qū)是一起的,它們在邏輯上依舊是分開的。但在物理上來說,它們又是連續(xù)的一塊內存。也就是說,方法區(qū)和前面講到的Eden和老年代是連續(xù)的。
在繼續(xù)進行下去之前,我們先來理解兩個概念:規(guī)范和實現(xiàn)。
針對Java虛擬機的實現(xiàn)有專門的《Java虛擬機規(guī)范》,在遵守規(guī)范的前提下,不同的廠商會對虛擬機進行不同的實現(xiàn)。 就好比開發(fā)的過程中定義了接口,具體的接口實現(xiàn)大家可以根據(jù)不同的業(yè)務需求進行實現(xiàn)。
PS:大家都有必要了解一下《Java虛擬機規(guī)范×××”,回復“002”獲得Java SE 7的虛擬機規(guī)范PDF版。
我們通常使用的Java SE都是由Sun JDK和OpenJDK所提供,這也是應用最廣泛的版本。而該版本使用的VM就是HotSpot VM。通常情況下,我們所講的java虛擬機指的就是HotSpot的版本。
上面理解了規(guī)范和實現(xiàn)之后,來看認識一個概念“永久代(Permanet Generation,也稱PermGen)”。對于習慣了在HotSpot虛擬機上開發(fā)、部署的程序員來說,很多都愿意將方法區(qū)稱作永久代。
本質上來講兩者并不等價,僅因為Hotspot將GC分代擴展至方法區(qū),或者說使用永久代來實現(xiàn)方法區(qū)。在其他虛擬機上是沒有永久代的概念的。也就是說方法區(qū)是規(guī)范,永久代是Hotspot針對該規(guī)范進行的實現(xiàn)。
理解上面的概念之后,我們對Java7及以前版本的堆和方法區(qū)的構造再進行一下變動。
再重復一遍就是對Java7及以前版本的Hotspot中方法區(qū)位于永久代中。同時,永久代和堆是相互隔離的,但它們使用的物理內存是連續(xù)的。
永久代的垃圾收集是和老年代捆綁在一起的,因此無論誰滿了,都會觸發(fā)永久代和老年代的垃圾收集。
但在Java7中永久代中存儲的部分數(shù)據(jù)已經開始轉移到Java Heap或Native Memory中了。比如,符號引用(Symbols)轉移到了Native Memory;字符串常量池(interned strings)轉移到了Java Heap;類的靜態(tài)變量(class statics)轉移到了Java Heap。
然后,在Java8中,時代變了,Hotspot取消了永久代。永久代真的成了永久的記憶。永久代的參數(shù)-XX:PermSize和-XX:MaxPermSize也隨之失效。
對于Java8,HotSpots取消了永久代,那么是不是就沒有方法區(qū)了呢?當然不是,方法區(qū)只是一個規(guī)范,只不過它的實現(xiàn)變了。
在Java8中,元空間(Metaspace)登上舞臺,方法區(qū)存在于元空間(Metaspace)。同時,元空間不再與堆連續(xù),而且是存在于本地內存(Native memory)。
本地內存(Native memory),也稱為C-Heap,是供JVM自身進程使用的。當Java Heap空間不足時會觸發(fā)GC,但Native memory空間不夠卻不會觸發(fā)GC。
針對Java8的調整,我們再次對內存結構圖進行調整。
元空間存在于本地內存,意味著只要本地內存足夠,它不會出現(xiàn)像永久代中“java.lang.OutOfMemoryError: PermGen space”這種錯誤??瓷蠄D中的方法區(qū),是不是“膨脹”了。
默認情況下元空間是可以無限使用本地內存的,但為了不讓它如此膨脹,JVM同樣提供了參數(shù)來限制它使用的使用。
思考一下,為什么使用元空間替換永久代?
表面上看是為了避免OOM異常。因為通常使用PermSize和MaxPermSize設置永久代的大小就決定了永久代的上限,但是不是總能知道應該設置為多大合適, 如果使用默認值很容易遇到OOM錯誤。
當使用元空間時,可以加載多少類的元數(shù)據(jù)就不再由MaxPermSize控制, 而由系統(tǒng)的實際可用空間來控制。
更深層的原因還是要合并HotSpot和JRockit的代碼,JRockit從來沒有所謂的永久代,也不需要開發(fā)運維人員設置永久代的大小,但是運行良好。同時也不用擔心運行性能問題了,在覆蓋到的測試中, 程序啟動和運行速度降低不超過1%,但是這點性能損失換來了更大的安全保障。
經過上面的講解和演變,是不是對JVM的內存結構有了更深的理解了?可以和面試官多聊一會兒了,畢竟面試官的時間也不多了。
創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國云服務器,動態(tài)BGP最優(yōu)骨干路由自動選擇,持續(xù)穩(wěn)定高效的網絡助力業(yè)務部署。公司持有工信部辦法的idc、isp許可證, 機房獨有T級流量清洗系統(tǒng)配攻擊溯源,準確進行流量調度,確保服務器高可用性。佳節(jié)活動現(xiàn)已開啟,新人活動云服務器買多久送多久。