溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

垃圾回收器怎么判斷哪些是可以被回收的對象

發(fā)布時(shí)間:2020-06-04 10:06:29 來源:億速云 閱讀:277 作者:Leah 欄目:編程語言

垃圾回收器怎么判斷哪些是可以被回收的對象?針對這個(gè)問題,今天小編總結(jié)這篇有關(guān)垃圾回收器算法應(yīng)用的文章,可供感興趣的小伙伴們參考借鑒,希望對大家有所幫助。

  1. 引用計(jì)數(shù)算法:
    給對象添加一個(gè)引用計(jì)數(shù)器,每當(dāng)它被引用一次計(jì)數(shù)器就加一,當(dāng)該引用失效時(shí)就減一,如果計(jì)數(shù)器的值為0就表示它要被垃圾收集器作為垃圾收集了。這種算法存在一個(gè)問題,就是如果對象之間互相循環(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ù)器不為空,垃圾收集器無法回收他們。

  1. 可達(dá)性分析算法:
    通過一系列稱為“GC Roots”的對象作為起點(diǎn),從這些節(jié)點(diǎn)開始向下搜索,搜索所走過的路徑稱為引用鏈,當(dāng)一個(gè)對象到Gc roots沒有任何引用鏈相連時(shí)則此對象是不可用的。

上圖中obj1,obj2,obj3都有引用指向Gc Roots,obj4和obj5沒有指向Gc Roots的引用,所以他們會作為垃圾回收器的對象??蛇_(dá)性分析算法是java中使用的算法。
可以作為Gc Roots的對象包括以下幾種:
1)  虛擬機(jī)棧(棧幀中的本地變量表)中引用的對象
2)  方法區(qū)中類靜態(tài)屬性引用的對象
3)  方法區(qū)中常量引用的對象
4)  本地方法棧中引用的對象

引用計(jì)數(shù)算法和可達(dá)性分析算法都和引用有關(guān),在jdk1.2以后引用被分為四種:

  1. 強(qiáng)引用:
    強(qiáng)引用就是例如  ObjectA a = new ObjectA(),這樣的引用,存在這種引用的對象不會被垃圾回收器回收。
    2:軟引用:
    軟引用是指一些引用還有用但并非必須,被軟引用的對象會在內(nèi)存被占滿,即將發(fā)生內(nèi)存溢出異常之前進(jìn)行回收。
    3:弱引用:被弱引用的對象只能生存到下一次垃圾回收發(fā)生之前,當(dāng)下一次垃圾回收時(shí),無論內(nèi)存是否被占滿都會回收弱引用的對象。
    4:虛引用,被虛引用的對象和沒有被引用的對象一樣都會被垃圾回收器回收,不同的是,它在被回收時(shí)會收到一個(gè)系統(tǒng)通知。
  2. 關(guān)于jvm
  3. 垃圾回收器的使用
  4. 就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。
向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI