垃圾回收器怎么判斷哪些是可以被回收的對(duì)象?針對(duì)這個(gè)問題,今天小編總結(jié)這篇有關(guān)垃圾回收器算法應(yīng)用的文章,可供感興趣的小伙伴們參考借鑒,希望對(duì)大家有所幫助。
創(chuàng)新互聯(lián)公司主營郫都網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,app軟件開發(fā)公司,郫都h5小程序定制開發(fā)搭建,郫都網(wǎng)站營銷推廣歡迎郫都等地區(qū)企業(yè)咨詢
- 引用計(jì)數(shù)算法:
給對(duì)象添加一個(gè)引用計(jì)數(shù)器,每當(dāng)它被引用一次計(jì)數(shù)器就加一,當(dāng)該引用失效時(shí)就減一,如果計(jì)數(shù)器的值為0就表示它要被垃圾收集器作為垃圾收集了。這種算法存在一個(gè)問題,就是如果對(duì)象之間互相循環(huán)引用,他們就不可能被垃圾回收。
舉個(gè)栗子:
public class RefrenceCounting {
public Object instance = null;
}
public class TestGc {
public static void main(String[] args) {
RefrenceCounting rf1 = new RefrenceCounting();
RefrenceCounting rf2 = new RefrenceCounting();
rf1.instance = rf2;
rf2.instance = rf1;
rf1 = null;
rf2 = null;
System.gc();
}
}
從圖中可以看到,rf1和rf2互相引用,即使rf1和rf2置空,從外界無法訪問他們,但是他們的引用計(jì)數(shù)器不為空,垃圾收集器無法回收他們。
- 可達(dá)性分析算法:
通過一系列稱為“GC Roots”的對(duì)象作為起點(diǎn),從這些節(jié)點(diǎn)開始向下搜索,搜索所走過的路徑稱為引用鏈,當(dāng)一個(gè)對(duì)象到Gc roots沒有任何引用鏈相連時(shí)則此對(duì)象是不可用的。
上圖中obj1,obj2,obj3都有引用指向Gc Roots,obj4和obj5沒有指向Gc Roots的引用,所以他們會(huì)作為垃圾回收器的對(duì)象。可達(dá)性分析算法是java中使用的算法。
可以作為Gc Roots的對(duì)象包括以下幾種:
1) 虛擬機(jī)棧(棧幀中的本地變量表)中引用的對(duì)象
2) 方法區(qū)中類靜態(tài)屬性引用的對(duì)象
3) 方法區(qū)中常量引用的對(duì)象
4) 本地方法棧中引用的對(duì)象
引用計(jì)數(shù)算法和可達(dá)性分析算法都和引用有關(guān),在jdk1.2以后引用被分為四種:
- 強(qiáng)引用:
強(qiáng)引用就是例如 ObjectA a = new ObjectA(),這樣的引用,存在這種引用的對(duì)象不會(huì)被垃圾回收器回收。
2:軟引用:
軟引用是指一些引用還有用但并非必須,被軟引用的對(duì)象會(huì)在內(nèi)存被占滿,即將發(fā)生內(nèi)存溢出異常之前進(jìn)行回收。
3:弱引用:被弱引用的對(duì)象只能生存到下一次垃圾回收發(fā)生之前,當(dāng)下一次垃圾回收時(shí),無論內(nèi)存是否被占滿都會(huì)回收弱引用的對(duì)象。
4:虛引用,被虛引用的對(duì)象和沒有被引用的對(duì)象一樣都會(huì)被垃圾回收器回收,不同的是,它在被回收時(shí)會(huì)收到一個(gè)系統(tǒng)通知。 - 關(guān)于jvm
垃圾回收器的使用- 就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。
當(dāng)前標(biāo)題:垃圾回收器怎么判斷哪些是可以被回收的對(duì)象
網(wǎng)站鏈接:
http://weahome.cn/article/gsipdd.html