垃圾回收機(jī)制
不定時(shí)的回收不可達(dá)的對象徙融。
什么是不可達(dá)對象
沒有被使用的對象毁菱。
怎么判斷對象是否可達(dá)
1、引用計(jì)數(shù)算法
大概的意思就是對象被引用一次加一衷佃,取消引用一次減一趟卸。但是有一個(gè)致命的缺點(diǎn)就是對象互相引用。所以該算法jvm不使用纲酗。
2衰腌、可達(dá)性算法
通過一些系列GCROOT作為根節(jié)點(diǎn),當(dāng)一個(gè)對象跟根節(jié)點(diǎn)沒有任何相連時(shí)觅赊,則認(rèn)為該對象為垃圾對象右蕊。
什么才能做為GCROOT
可以這樣想就知道,堆中數(shù)據(jù)是共享數(shù)據(jù)吮螺,那么誰來使用共享數(shù)據(jù)饶囚,誰就是GCROOT。
如:
- 虛擬機(jī)棧中的局部變量表鸠补。如:
void methoda() {
Object object = new Object();
}
- 方法區(qū)
如:
private static ClassA = ClassA.getInstance();
- 本地方法棧
void methoda() {
Object object = new Object();
}
怎么回收不可達(dá)對象萝风,也就是垃圾對象
通過垃圾回收算法進(jìn)行回收
- 標(biāo)記-清除
描述:先標(biāo)記出需要回收的對象,標(biāo)記完成后進(jìn)行清除紫岩。
缺點(diǎn):清除之后规惰,沒有做碎片整理,會(huì)導(dǎo)致需要大內(nèi)存的對象無法存儲(chǔ)泉蝌。如:堆內(nèi)存零碎空間加起來還有10M歇万,正好新對象所需的內(nèi)存空間也是10M,但是他放不進(jìn)去勋陪,因?yàn)闆]有一個(gè)完整的空間容納贪磺。 - 標(biāo)記-整理
對標(biāo)記-刪除算法一種優(yōu)化,也就是刪除之后诅愚,還能幫我做碎片整理寒锚。
缺點(diǎn):碎片整理復(fù)雜。
適用場景:老年代。 - 復(fù)制
可以說是對標(biāo)記-整理進(jìn)行了優(yōu)化刹前,因?yàn)椴挥每紤]整理碎片整理問題泳赋,但是它是以犧牲空間為代價(jià)。
描述:內(nèi)存一分為二(使用區(qū)和未使用區(qū))腮郊,首先標(biāo)記出需要回收的對象摹蘑,然后將不需要回收的對象未使用區(qū),接著將之前的使用區(qū)全部清空轧飞,變成了未使用區(qū)衅鹿。
缺點(diǎn):如果可用的對象很多,復(fù)制會(huì)消耗性能过咬。
適用場景:可用對象不是很多時(shí)大渤。如:新生代
新生代和老年代概念是從分代收集提出的,分代收集是針對著垃圾回收特點(diǎn)不同掸绞,將Java堆分為新生代和老年代泵三,新生代采用復(fù)制算法,老年代采用標(biāo)記-整理或標(biāo)記-刪除
新生代工作流程
第一個(gè)minor gc流程
Eden滿時(shí)衔掸,發(fā)生一次minor gc烫幕,將存活的對象移動(dòng)到from區(qū)。
第二次minor gc流程
Eden滿時(shí)敞映,發(fā)生一次minor gc较曼,將Eden和from區(qū)存活對象移動(dòng)到to區(qū),清除Eden和from區(qū)振愿。
第三次minor gc流程
Eden滿時(shí)捷犹,發(fā)生一次minor gc,將Eden和to區(qū)存活對象移動(dòng)到from區(qū)冕末,清除Eden和to區(qū)萍歉。
標(biāo)記-清除、標(biāo)準(zhǔn)-整理档桃、復(fù)制算法實(shí)現(xiàn)枪孩,也就是垃圾回收器
類加載機(jī)制
什么是類加載機(jī)制
虛擬機(jī)把class文件加載到內(nèi)存,并對數(shù)據(jù)進(jìn)行驗(yàn)證藻肄、準(zhǔn)備销凑、解析和初始化,最終轉(zhuǎn)換到虛擬機(jī)直接能使用的java類型仅炊。
初始化時(shí)機(jī)
1、new時(shí)
2澎蛛、反射時(shí)
類加載器
從jvm來講抚垄,分為兩種,一種是bootstarpclassloader啟動(dòng)類加載器,所有其他的類加載器呆馁。
從java開發(fā)者角度來講桐经,分為四種,bootstrapclassloader啟動(dòng)類加載器浙滤、擴(kuò)展類加載器阴挣、系統(tǒng)加載器和自定義加載器
JVM默認(rèn)使用雙親委派類加載機(jī)制,意思是說先加載父類在加載子類
雙親委托模型機(jī)制
一個(gè)類加載器收到加載類請求時(shí)纺腊,它不會(huì)嘗試去加載類畔咧,而是委托給其父類加載器去完成,但父類加載器不能完成這個(gè)加載請求時(shí)揖膜,子類加載器才會(huì)嘗試去加載誓沸。
運(yùn)行時(shí)數(shù)據(jù)區(qū)
程序計(jì)數(shù)器
簡單理解,就是一個(gè)程序執(zhí)行順序的標(biāo)記壹粟。
虛擬機(jī)棧
虛擬機(jī)棧是線程私有的拜隧,每個(gè)方法在執(zhí)行時(shí),都會(huì)創(chuàng)建一個(gè)棧幀存放到虛擬機(jī)棧中趁仙,執(zhí)行完畢后洪添,從虛擬機(jī)棧中移出。創(chuàng)建棧幀的目的是為了存放局部變量表雀费、操作數(shù)棧和動(dòng)態(tài)鏈接干奢。
堆
堆是共享數(shù)據(jù)區(qū),用于存放對象實(shí)例和數(shù)組坐儿。
方法區(qū)
方法區(qū)是共享數(shù)據(jù)區(qū)律胀,用戶存放類信息,常量貌矿,靜態(tài)變量炭菌,靜態(tài)方法。