一、概要
2.Java虛擬機是用來干什么的?
3.Java虛擬機它的體系結(jié)構(gòu)是什么樣子的?
4.Java虛擬機在工作做扮演什么角色?
5.Java虛擬機在運行時數(shù)據(jù)區(qū)?
二、Jvm基礎(chǔ)概念
Java虛擬機(Jvm)是可運行Java代碼的假想計算機。
Java虛擬機包括一套字節(jié)碼指令集、一組寄存器、一個棧、一個垃圾回收堆和一個存儲方法域。
在了解Jvm之前,大家如果有興趣的,也可以先去了解下Java 中的堆和棧。
三、Jvm
我們都知道Java源文件,通過編譯器,能夠生產(chǎn)相應(yīng)的.Class文件,也就是字節(jié)碼文件,而字節(jié)碼文件又通過Java虛擬機中的解釋器,也就是前面所有的Java虛擬機中的字節(jié)碼指令
集,編譯成特定機器上的機器碼。
如下:
1.Java源文件—->編譯器—->字節(jié)碼文件
2.字節(jié)碼文件—->Jvm—->機器碼
每一種平臺的解釋器是不同的,但是實現(xiàn)的虛擬機是相同的。這也就是Java為什么能夠跨平臺的原因了。當(dāng)開始運行一個程序,這時虛擬機就開始實例化了。多個程序啟動就會存在多個虛擬機實例。程序退出或者關(guān)閉。則虛擬機實例消亡。多個虛擬機實例之間數(shù)據(jù)不能共享。
四、Jvm的體系結(jié)構(gòu)
Jvm的體系結(jié)構(gòu)入下圖:
1、垃圾回收器
垃圾回收器(縮寫為gc):顧名思義是負(fù)責(zé)回收內(nèi)存中無用的對象,就是這些對象沒有任何引用了,它就會被視為:垃圾,就會被清理掉。
2、類裝載子系統(tǒng)
一聽名字,大家就知道,肯定是用于操作我們編譯好的.Class文件的系統(tǒng),他作用如下:
1.定位和導(dǎo)入二進(jìn)制class文件 ;
2.驗證導(dǎo)入類的正確性 ;
3.為類分配初始化內(nèi)存 ;
4.幫助解析符號引用;
3、執(zhí)行引擎(Execution Engine)
執(zhí)行包在裝載類的方法中的指令,也就是方法
4、運行區(qū)數(shù)據(jù)
虛擬機內(nèi)存或者Jvm內(nèi)存,沖整個計算機內(nèi)存中開辟一塊內(nèi)存存儲Jvm需要用到的對象,變量等,運行區(qū)數(shù)據(jù)又分很多小區(qū),分別為:方法區(qū),虛擬機棧,本地方法棧,堆,程序計數(shù)器
五、Jvm運行時數(shù)據(jù)區(qū)
1.程序計數(shù)器
當(dāng)前線程執(zhí)行字節(jié)碼的信號指示器,線程是私有的,它的生命周期和線程相同分支、循環(huán)、跳轉(zhuǎn)、異常處理、線程恢復(fù)等基礎(chǔ)功能都需要依賴這個計數(shù)器來完成。
2.虛擬機棧
Java虛擬機棧描述的是Java方法(區(qū)別于native的本地方法)執(zhí)行的內(nèi)存模型:每個方法被執(zhí)行的時候都會同時創(chuàng)建一個棧幀(Stack Frame)用于存儲局部變量表、操作棧、動作鏈接、方法出口等信息。
線程私有,生命周期和線程相同,都有各個獨立的計數(shù)器,各不影響。
每個方法被調(diào)用直至執(zhí)行完成的過程,就對應(yīng)著一個棧幀在虛擬機棧中從入棧到出棧的過程。
3.本地方法棧
和虛擬機方法棧差不多類似,但是本地方法棧是服務(wù)于虛擬機所使用到的Native方法服務(wù)
4.本地方法區(qū):
只是執(zhí)行Native 方法。如果這個區(qū)的內(nèi)存不足也是會拋出StackOverflowError 和OutOfMemoryError 異常。
六、堆
堆這塊區(qū)域是Jvm中最大的,應(yīng)用的對象和數(shù)據(jù)都是存在這個區(qū)域。這塊區(qū)域也是線程共享的。也是 gc 主要的回收區(qū)。其實這也就是大家聽的比較多的:Java (gc)垃圾回收器。