Java運(yùn)行時(shí)數(shù)據(jù)區(qū)概述詳解
Java 虛擬機(jī)在執(zhí)行Java程序的過程中會把它所管理的內(nèi)存劃分為若干個不同的數(shù)據(jù)區(qū)域,這些區(qū)域都有各自的用途,如圖所示:

程序計(jì)數(shù)器
程序計(jì)數(shù)器是一塊比較小的內(nèi)存空間,可以看作是當(dāng)前線程所執(zhí)行的字節(jié)碼的行號指示器。
在虛擬機(jī)的概念模型中(僅是概念模型,各種虛擬機(jī)可能會通過一些更加高效的方式去實(shí)現(xiàn)),字節(jié)碼解釋器工作時(shí)就是通過改變這個計(jì)數(shù)器的值來選取下一條需要執(zhí)行的字節(jié)碼指令,分支、循環(huán)、跳轉(zhuǎn)、異常處理、線程恢復(fù)等基礎(chǔ)功能都需要依賴這個計(jì)數(shù)器來完成。
如果線程正在執(zhí)行一個Java方法,則這個計(jì)數(shù)器記錄的正是正在執(zhí)行的虛擬機(jī)字節(jié)碼指令的地址;如果正在執(zhí)行的是Native方法,則這個計(jì)數(shù)器值為空。
此內(nèi)存區(qū)域是唯一一個在Java虛擬機(jī)規(guī)范中沒有規(guī)定任何 OutOfMemoryError 情況的區(qū)域。
Java虛擬機(jī)棧
Java虛擬機(jī)棧和程序計(jì)數(shù)器一樣,都是線程私有的。
Java虛擬機(jī)棧描述的是Java方法執(zhí)行的內(nèi)存模型:每個方法在執(zhí)行的時(shí)候都會創(chuàng)建一個棧幀用于存儲局部變量表、操作數(shù)幀、動態(tài)鏈接、方法出口等信息。每一個方法從調(diào)用直至執(zhí)行完成的過程,就對應(yīng)著一個棧幀在虛擬機(jī)中入棧到出棧的過程。
局部變量表存放了編譯器可知的各種基本數(shù)據(jù)類型,它所需要的內(nèi)存空間在編譯期間完成分配,當(dāng)進(jìn)入一個方法時(shí),這個方法需要在幀中分配多大的局部變量空間是完全確定的,在方法運(yùn)行期間不會改變局部變量表的大小。
在Java虛擬機(jī)規(guī)范中,對這個區(qū)域規(guī)定了兩種異常狀況,如果線程請求的棧深度大于虛擬機(jī)所允許的深度,將會拋出 StackOverflowError 異常;如果虛擬機(jī)棧可以動態(tài)拓展,如果擴(kuò)展時(shí)無法申請到足夠的內(nèi)存,就會拋出OutOfMemoryError 異常。
本地方法棧
本地方法棧與虛擬機(jī)棧所發(fā)揮的作用是非常相似的,但是本地方法棧為虛擬機(jī)使用Native方法服務(wù)。
Java堆
對于大多數(shù)應(yīng)用來說,Java堆是JavaScript虛擬機(jī)所管理的內(nèi)存中最大的一塊。Java堆是被所有線程共享的一塊內(nèi)存區(qū)域,在虛擬機(jī)啟動時(shí)創(chuàng)建。
此內(nèi)存區(qū)域的唯一目的就是存放對象實(shí)例,幾乎所有的對象實(shí)例都要在堆上分配。
Java堆是垃圾收集器管理的主要區(qū)域,因此很多時(shí)候也被稱為 “GC堆”。
根據(jù)Java虛擬機(jī)規(guī)范的規(guī)定,Java堆可以處于物理上不連續(xù)的內(nèi)存空間中,只要邏輯上是連續(xù)的即可。如果堆中沒有內(nèi)存完成實(shí)例分配,并且堆也無法再拓展時(shí),將會拋出 OutOfMemoryError 異常。
方法區(qū)
方法區(qū)與Java堆一樣,是各個線程共享的內(nèi)存區(qū)域,它用于存儲已被虛擬機(jī)加載的類信息、常量、靜態(tài)變量、即使編譯器編譯后的代碼等數(shù)據(jù)
雖然Java虛擬機(jī)規(guī)范把方法區(qū)描述為堆的一個邏輯部分,但是它卻有一個別名叫做 Non-Heap(非堆),目的可能是和Java堆區(qū)分開來。
對于習(xí)慣在HotSpot虛擬機(jī)上開發(fā)、部署程序的開發(fā)者而言,很多人更愿意將方法區(qū)稱為“永久代”。本質(zhì)上兩者并不等價(jià),僅僅是因?yàn)镠otSpot虛擬機(jī)的設(shè)計(jì)團(tuán)隊(duì)選擇把GC分代手機(jī)擴(kuò)展到方法區(qū),這樣HotSpot的垃圾收集器就可以像管理Java堆一樣管理這部分內(nèi)存。但這看起來不是一個好主意,因?yàn)楦菀子龅絻?nèi)存溢出問題。
當(dāng)方法區(qū)無法滿足內(nèi)存分配需求時(shí),將拋出OutOfMemoryError 異常。
以上所述是小編給大家介紹的Java運(yùn)行時(shí)數(shù)據(jù)區(qū)概述詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
springboot CompletableFuture并行計(jì)算及使用方法
CompletableFuture基于 Future 和 CompletionStage 接口,利用線程池、回調(diào)函數(shù)、異常處理、組合操作等機(jī)制,提供了強(qiáng)大而靈活的異步編程功能,這篇文章主要介紹了springboot CompletableFuture并行計(jì)算及使用方法,需要的朋友可以參考下2024-05-05
解決Java中的強(qiáng)制類型轉(zhuǎn)換和二進(jìn)制表示問題
這篇文章主要介紹了解決Java中的強(qiáng)制類型轉(zhuǎn)換和二進(jìn)制表示問題,需要的朋友可以參考下2019-05-05
JavaWeb三大組件之監(jiān)聽器Listener詳解
這篇文章主要介紹了JavaWeb三大組件之監(jiān)聽器Listener詳解,在JavaWeb應(yīng)用程序中,Listener監(jiān)聽器是一種機(jī)制,用于監(jiān)聽和響應(yīng)特定的事件,它可以感知并響應(yīng)與應(yīng)用程序相關(guān)的事件,從而執(zhí)行相應(yīng)的邏輯處理,需要的朋友可以參考下2023-10-10
Java使用flyway實(shí)現(xiàn)腳本自動化的方法詳解
Flyway是一個開源的數(shù)據(jù)庫版本控制工具,主要用于管理數(shù)據(jù)庫的版本和變更,它可以自動化地將數(shù)據(jù)庫遷移到不同的版本,同時(shí)支持多種數(shù)據(jù)庫類型,本文給大家介紹了如何使用flyway實(shí)現(xiàn)腳本自動化,需要的朋友可以參考下2023-10-10

