1. 創(chuàng)建階段(Created)
● 為對(duì)象分配存儲(chǔ)空間
● 開(kāi)始構(gòu)造對(duì)象
● 從父類到子類對(duì)static成員進(jìn)行初始化
● 父類成員變量按照順序初始化刚操,遞歸調(diào)用父類的構(gòu)造方法
● 子類成員變量按照順序初始化,子類構(gòu)造方法調(diào)用
一旦對(duì)象被創(chuàng)建员舵,并有某個(gè)引用指向它,這個(gè)對(duì)象的狀態(tài)就切換到了應(yīng)用階段(In Use)
2. 應(yīng)用階段(In Use)
對(duì)象至少被一個(gè)強(qiáng)引用持有并且對(duì)象在作用域內(nèi)
3. 不可見(jiàn)階段(Invisible)
程序本身不再持有該對(duì)象的任何強(qiáng)引用缨历,但是這些引用可能還存在著儒老;
一般具體是指程序的執(zhí)行已經(jīng)超過(guò)該對(duì)象的作用域了
boolean isChild = false;
if (isChild) {
int age = 1;
for (int i = 1; i < 30; i++) {
age = i;
}
}
System.out.println(age); // age不可見(jiàn)
4. 不可達(dá)階段(Unreachable)
該對(duì)象不再被任何強(qiáng)引用所持有;
可能仍被JVM等系統(tǒng)下的某些已經(jīng)裝載的靜態(tài)變量或者線程或JNI所持有挣棕,這些特殊的強(qiáng)引用被稱為GC root,這種情況容易導(dǎo)致內(nèi)存泄露,無(wú)法被回收
靜態(tài)變量亲桥、JNI洛心、Thread一般容易成為GCRoot對(duì)象,被它們持有的對(duì)象容易發(fā)生內(nèi)存泄露
5. 收集階段(Collected)
對(duì)象不可達(dá)两曼,并且GC已經(jīng)準(zhǔn)備好對(duì)該對(duì)象占用的內(nèi)存空間重新分配的時(shí)候皂甘,處于手機(jī)階段玻驻。
如果重寫了finazlie()方法悼凑,則會(huì)去執(zhí)行該方法偿枕。
盡量不要重寫finazlie()方法,因?yàn)橛锌赡苡绊慗VM的對(duì)象分配與回收速度或者可能造成該對(duì)象的再次復(fù)活
6. 終結(jié)階段
當(dāng)對(duì)象執(zhí)行完finalize()方法之后户辫,仍然處于不可達(dá)狀態(tài)時(shí)渐夸,則該對(duì)象進(jìn)入終結(jié)階段。在這個(gè)階段渔欢,內(nèi)存空間等待GC進(jìn)行回收
7. 對(duì)象空間的重新分配
GC對(duì)該對(duì)象占有的內(nèi)存空間進(jìn)行回收或者再分配墓塌,該對(duì)象徹底消失