今天就跟大家聊聊有關(guān)JVM運行時的數(shù)據(jù)區(qū)域,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
成都創(chuàng)新互聯(lián)公司是創(chuàng)新、創(chuàng)意、研發(fā)型一體的綜合型網(wǎng)站建設(shè)公司,自成立以來公司不斷探索創(chuàng)新,始終堅持為客戶提供滿意周到的服務,在本地打下了良好的口碑,在過去的10余年時間我們累計服務了上千家以及全國政企客戶,如宣傳片制作等企業(yè)單位,完善的項目管理流程,嚴格把控項目進度與質(zhì)量監(jiān)控加上過硬的技術(shù)實力獲得客戶的一致稱揚。
首先看圖:
1.程序計數(shù)器(PC)
是線程獨享的。是一塊較小的內(nèi)存,是當前線程所執(zhí)行的字節(jié)碼的行號指示器,是Java虛擬機規(guī)范中唯一沒有被規(guī)定OOM(OutOfMemoryError)的區(qū)域。
2.Java虛擬機棧
是線程獨享的。生命周期和線程相同。是Java方法執(zhí)行的內(nèi)存模型。執(zhí)行每個方法都會創(chuàng)建一個棧幀,用于存儲局部變量和操作數(shù)(對象引用)。局部變量所需要的內(nèi)存空間大小在編譯期間完成分配。所以棧幀的大小是不會改變的。
存在兩種異常情況:
1)若線程請求深度大于棧的深度,會拋出StackOverFlowError。
2)若棧在動態(tài)擴展的時候無法請求足夠的內(nèi)存,會拋出OOM。
3.堆
Java堆是所有線程共享的。是虛擬機啟動的時候創(chuàng)建的。存放的是對象的實例和數(shù)組。所占內(nèi)存最大。分為新生代(Young區(qū))、老年代(Old區(qū))。新生代又分為Eden區(qū)、Servior區(qū)。Servior區(qū)又分為From space區(qū)和To space區(qū)。Eden區(qū)和Servior區(qū)的內(nèi)存比例為8:1。當擴展內(nèi)存大于可用內(nèi)存的時候,會拋出OOM。
4.本地方法棧
本地方法棧是線程獨享的。與Java虛擬機棧類似,但不是為Java方法(字節(jié)碼)服務,而是為本地非Java方法服務。也會拋出StackOverFlowError和OOM。
5.方法區(qū)
方法區(qū)是所有線程共享的。用于存儲已經(jīng)被虛擬機加載的類信息、常量、靜態(tài)變量等數(shù)據(jù),又稱為非堆(Non-Heap)。方法區(qū)又稱為“永久代”,GC很少在這個區(qū)域進行,但不代表不會回收。這個區(qū)域回收目標主要是針對常量池的回收和對類型的卸載。當內(nèi)存申請大于實際可用內(nèi)存時,會拋出OOM。
看完上述內(nèi)容,你們對JVM運行時的數(shù)據(jù)區(qū)域介紹有進一步的了解嗎?如果還想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀。