微信公眾號(hào): Spark大數(shù)據(jù)
JVM虛擬機(jī)詳解
程序計(jì)數(shù)器
內(nèi)存空間小谍肤,線程私有。字節(jié)碼解釋器工作是就是通過(guò)改變這個(gè)計(jì)數(shù)器的值來(lái)選取下一條需要執(zhí)行指令的字節(jié)碼指令哗伯,分支荒揣、循環(huán)、跳轉(zhuǎn)笋颤、異常處理、線程恢復(fù)等基礎(chǔ)功能都需要依賴計(jì)數(shù)器完成内地“槌危總而言之,程序計(jì)數(shù)器是為線程間跳轉(zhuǎn)服務(wù)的阱缓。
如果線程正在執(zhí)行一個(gè) Java 方法非凌,這個(gè)計(jì)數(shù)器記錄的是正在執(zhí)行的虛擬機(jī)字節(jié)碼指令的地址;如果正在執(zhí)行的是 Native 方法荆针,這個(gè)計(jì)數(shù)器的值則為 (Undefined)敞嗡。此內(nèi)存區(qū)域是唯一一個(gè)在 Java 虛擬機(jī)規(guī)范中沒(méi)有規(guī)定任何 OutOfMemoryError 情況的區(qū)域。
Java虛擬機(jī)棧
線程私有航背,生命周期和線程一致喉悴。描述的是 Java 方法執(zhí)行的內(nèi)存模型:每個(gè)方法在執(zhí)行時(shí)都會(huì)床創(chuàng)建一個(gè)棧幀(Stack Frame)用于存儲(chǔ)局部變量表、操作數(shù)棧玖媚、動(dòng)態(tài)鏈接箕肃、方法出口等信息。每一個(gè)方法從調(diào)用直至執(zhí)行結(jié)束今魔,就對(duì)應(yīng)著一個(gè)棧幀從虛擬機(jī)棧中入棧到出棧的過(guò)程勺像。
局部變量表:存放了編譯期可知的八種基本類型、對(duì)象引用(reference 類型)和 returnAddress 類型(指向了一條字節(jié)碼指令的地址)错森。
Java虛擬機(jī)椧骰拢可能出現(xiàn)兩種類型的異常:線程請(qǐng)求的棧深度大于虛擬機(jī)允許的棧深度,將拋出StackOverflowError涩维。虛擬機(jī)椦晷眨空間可以動(dòng)態(tài)擴(kuò)展,當(dāng)動(dòng)態(tài)擴(kuò)展是無(wú)法申請(qǐng)到足夠的空間時(shí),拋出OutOfMemory異常辰狡。
本地方法棧
它是為本地方法服務(wù)的锋叨,而本地方法棧則為虛擬機(jī)使用到的 Native 方法服務(wù), jdk版本不同宛篇,本地方法椡藁牵可能不同,有些特殊版本把棧和本地方法棧二合一 叫倍。也會(huì)有 StackOverflowError 和 OutOfMemoryError 異常偷卧。
堆
jvm內(nèi)存只有一個(gè)堆,所有線程共享這個(gè)堆吆倦,幾乎所有的對(duì)象都存放在堆里听诸。堆是內(nèi)存空間最大的一塊,相對(duì)的運(yùn)行速度是最慢的蚕泽。垃圾回收指的就是回收堆里的內(nèi)存垃圾晌梨,所有 new的象都會(huì)在堆里。
垃圾回收機(jī)制和堆须妻,為什么堆里會(huì)有垃圾 ?
當(dāng)你創(chuàng)建一個(gè)對(duì)象仔蝌,這個(gè)對(duì)象使用完畢之后就是垃圾,當(dāng)一個(gè)對(duì)象沒(méi)有任何一個(gè)地址可以指向它的時(shí)候荒吏,它就是不可達(dá)的對(duì)象敛惊。
jvm 垃圾回收機(jī)制回收的就是不可達(dá)的對(duì)象,目前 jvm 垃圾回收機(jī)制用的是科學(xué)分析法 绰更,它會(huì)遍歷堆里的對(duì)象瞧挤,然后檢測(cè)是否有地址可達(dá)這個(gè)對(duì)象,如果不可達(dá)那么就回收儡湾。注意:堆是不連續(xù)的空間特恬。
方法區(qū)
方法區(qū)有兩種說(shuō)法:
1. 被認(rèn)為是 堆得一部分 負(fù)責(zé)一部分特殊用途。
2. 和堆是不同概念 也不是一體的徐钠。
方法區(qū)主要分為三塊:
1.靜態(tài)區(qū)鸵鸥,靜態(tài)的東西都存儲(chǔ)在這個(gè)地方。
2.類信息區(qū)丹皱,字節(jié)碼被加載到內(nèi)存里 存儲(chǔ)在類信息區(qū)妒穴。
3.常量池,所有的常量存儲(chǔ)在常量池里摊崭。
什么是常量池 ?
常量池里存儲(chǔ)的都是常量讼油,有些類實(shí)現(xiàn)了常量池技術(shù),常量是為了減少常見(jiàn)的對(duì)象的創(chuàng)建呢簸。
什么是常量池技術(shù) ?以 字符串為例:String是不可變的字符串矮台,也就是說(shuō) String類的對(duì)象本身是不變的乏屯,是一個(gè)常量在你 String str = "大數(shù)據(jù)" 時(shí)。會(huì)首先到常量池中尋找瘦赫,查看是否有 "大數(shù)據(jù)" 這個(gè)字符串對(duì)象辰晕。
如果有,把該對(duì)象的地址給與 str存儲(chǔ)确虱,以后再有變量被賦值為 "大數(shù)據(jù)"時(shí)都會(huì)如此操作含友;如果沒(méi)有,那么就把 "哈大數(shù)據(jù)" 對(duì)象創(chuàng)建存入常量池校辩,然后地址為str窘问。
注意 :String類實(shí)現(xiàn)常量池在顯示賦值時(shí)支持常量池技術(shù),在new對(duì)象時(shí)不支持宜咒。