JVM系列(四)

GC一探究竟(一)

1. 前言

GC脱货,也即是垃圾收集碘菜,對(duì)幾乎所有的JAVA程序員來說,絕對(duì)是不陌生的米苹。Java與C語言不同糕伐,Java程序員不需要去管內(nèi)存的釋放,而C語言開發(fā)則需要程序員去手動(dòng)釋放內(nèi)存蘸嘶。而正是因?yàn)檫@種自動(dòng)化的機(jī)制良瞧,讓程序員無法人為的去控制內(nèi)存的釋放,因此可能會(huì)出現(xiàn)各種內(nèi)存溢出训唱,內(nèi)存泄漏的問題褥蚯。而這也正是我們需要去了解Java的內(nèi)存回收機(jī)制的必要原因。

在之前的文章中提到了Java運(yùn)行時(shí)數(shù)據(jù)區(qū)域的劃分况增,對(duì)于程序計(jì)數(shù)器赞庶,Java棧,本地方法棧這三個(gè)區(qū)域?qū)儆诰€程私有區(qū)域澳骤,隨線程而生尘执,隨線程而滅。因此GC不會(huì)去關(guān)注這部分內(nèi)存宴凉。而堆和方法區(qū)是屬于線程共享的區(qū)域誊锭,這部分的內(nèi)存和回收都是動(dòng)態(tài)的,只有在運(yùn)行期才能確定所需的內(nèi)存弥锄。因此GC回收的內(nèi)存和后續(xù)的“內(nèi)存“分配指的便是這部分內(nèi)存丧靡。

2. 如何成為該被回收的對(duì)象?

前面也提到了籽暇,Java堆中的對(duì)象的回收温治,我們Java程序員是無法進(jìn)行操縱的,而我們需要了解的是那對(duì)象是什么時(shí)候戒悠,什么情況下該被回收了熬荆。因此,介紹兩種判斷對(duì)象是否該成為被回收對(duì)象的算法绸狐,分別是引用計(jì)數(shù)算法和可達(dá)性分析算法卤恳。

2.1 引用計(jì)數(shù)算法

2.1.1 原理

給對(duì)象添加一個(gè)引用計(jì)數(shù)器,每當(dāng)對(duì)象增加一個(gè)引用的時(shí)候寒矿,計(jì)數(shù)器的值+1突琳,一個(gè)引用失效,則-1符相,任何時(shí)刻拆融,計(jì)數(shù)器為0的對(duì)象就是不可能會(huì)再被使用的了。

2.1.2 優(yōu)點(diǎn)

引用計(jì)數(shù)算法的實(shí)現(xiàn)簡單,而且判定的效率很高镜豹,只需要給對(duì)象增加一個(gè)引用計(jì)數(shù)器傲须,判斷引用計(jì)數(shù)器的值便能確定對(duì)象是否該被回收了

2.1.3 缺點(diǎn)

有利就有弊,引用計(jì)數(shù)法的簡單實(shí)現(xiàn)無法解決一個(gè)問題趟脂,那就是對(duì)象之間循環(huán)引用的問題躏碳。舉個(gè)栗子:

public class A{
    A a;
    
    public static void main(String [] args){
        A obj1 = new A();
        A obj2 = new B();
        
        obj1.a=obj2;
        obj2,a=obj1;
        
        obj1=null;
        obj2=null;
    }  
}

如上栗子,我們可以知道散怖,對(duì)象1和對(duì)象2的引用計(jì)數(shù)器的值最后是為1的,而根據(jù)我們以往的想法肄渗,obj1和obj2的引用置空之后镇眷,他們指向的對(duì)象就無法使用,應(yīng)該被回收了翎嫡,因此使用引用計(jì)數(shù)算法是無法滿足的欠动,所以Ho0Spot虛擬機(jī)使用的不是這種算法,而是接下來講的惑申。

2.2 可達(dá)性分析算法

2.2.1 原理

該算法是以一系列稱為“GC Roots“的對(duì)象為起點(diǎn)具伍,然后從這些節(jié)點(diǎn)開始向下搜索,搜索走過的路徑稱為引用鏈圈驼,當(dāng)一個(gè)對(duì)象到GC Roots沒有任何引用鏈的時(shí)候人芽,也就是GC Roots到這個(gè)對(duì)象是不可達(dá)的時(shí)候,這個(gè)對(duì)象便是不可用的了绩脆,因此可以作為回收的對(duì)象萤厅。

2.2.2 GC Roots

在java語言中,可以作為GC Roots的對(duì)象有以下幾種

  • 虛擬機(jī)棧(棧幀中的本地變量表)中的引用對(duì)象
  • 方法區(qū)中類靜態(tài)屬性引用的對(duì)象
  • 方法區(qū)中常量引用的對(duì)象
  • 本地方法JNI(Native方法)引用的對(duì)象

2.3 對(duì)象由標(biāo)記到死亡

前面介紹了如何確定一個(gè)對(duì)象可以被標(biāo)記為回收對(duì)象靴迫,那現(xiàn)在介紹下從標(biāo)記到回收的過程惕味。

要宣告一個(gè)對(duì)象真正死亡,至少經(jīng)過兩次標(biāo)記過程玉锌,當(dāng)使用可達(dá)性算法分析不可達(dá)的對(duì)象的時(shí)候名挥,對(duì)象被第一次標(biāo)記為不可達(dá)對(duì)象時(shí)候,會(huì)進(jìn)行一次篩選操作主守,當(dāng)對(duì)象沒有覆蓋或者調(diào)用過一次finalize方法時(shí)候禀倔,此時(shí)定義為對(duì)象沒必要執(zhí)行finalize方法。否則會(huì)判定為有必要執(zhí)行finalize方法参淫,而該方法是對(duì)象逃離死亡的最后一次機(jī)會(huì)蹋艺,只要在該方法中可以使得對(duì)象和引用鏈的任何一個(gè)對(duì)象關(guān)聯(lián)即可。(如黄刚,可將this賦值給某個(gè)類變量捎谨,或者對(duì)象的成員變量)只有這樣,在第二次標(biāo)記的時(shí)候才可以被移除“即將被回收的集合” 。否則涛救,第二次標(biāo)記的時(shí)候畏邢,基本上沒有逃脫的對(duì)象真的被回收了。

2.4 方法區(qū)的回收

前面講的GC內(nèi)容是關(guān)于堆中的對(duì)象的检吆,而在前言中也提到了舒萎,方法區(qū)也是GC涉及的一塊內(nèi)存區(qū)域。

很多人都認(rèn)為方法區(qū)(HotSpot虛擬機(jī)中的永久代)是沒有垃圾回收的蹭沛,但其實(shí)還是存在的臂寝,只不過在方法區(qū)的主要是廢棄常量和無用的類。

2.4.1 廢棄常量

廢棄常量和不可用對(duì)象的定義是差不多的摊灭,對(duì)于方法區(qū)的常量咆贬,假如外界沒有了引用這個(gè)常量的引用,那么這個(gè)常量便是一個(gè)廢棄常量帚呼,如“字面常量“abc“掏缎,假如程序中沒有String對(duì)象是”abc”,那說明沒有任何String對(duì)象引用到這個(gè)常量煤杀,因此這個(gè)常量就會(huì)被回收眷蜈。

2.4.1 無用的類

類需要同時(shí)滿足下面三個(gè)條件,才能算是無用的類

  • 該類的所有實(shí)例都被回收了沈自,即Java堆中不存在該類的任何實(shí)例
  • 加載該類的ClassLoader已經(jīng)被回收了
  • 該類對(duì)應(yīng)的java.lang.Class對(duì)象沒有在任何地方被引用酌儒,無法在任何地方通過反射訪問該類的方法

當(dāng)滿足上述三個(gè)條件的類才可以被回收,但是并不是一定會(huì)被回收枯途,需要參數(shù)進(jìn)行控制今豆,例如HotSpot虛擬機(jī)提供了-Xnoclassgc參數(shù)進(jìn)行控制是否回收。

歡迎關(guān)注本人博客:https://allen-yu.com/

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末柔袁,一起剝皮案震驚了整個(gè)濱河市呆躲,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌捶索,老刑警劉巖插掂,帶你破解...
    沈念sama閱讀 206,968評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異腥例,居然都是意外死亡辅甥,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門燎竖,熙熙樓的掌柜王于貴愁眉苦臉地迎上來璃弄,“玉大人,你說我怎么就攤上這事构回∠目椋” “怎么了疏咐?”我有些...
    開封第一講書人閱讀 153,220評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長脐供。 經(jīng)常有香客問我浑塞,道長,這世上最難降的妖魔是什么政己? 我笑而不...
    開封第一講書人閱讀 55,416評(píng)論 1 279
  • 正文 為了忘掉前任酌壕,我火速辦了婚禮,結(jié)果婚禮上歇由,老公的妹妹穿的比我還像新娘卵牍。我一直安慰自己,他們只是感情好沦泌,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,425評(píng)論 5 374
  • 文/花漫 我一把揭開白布糊昙。 她就那樣靜靜地躺著,像睡著了一般赦肃。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上公浪,一...
    開封第一講書人閱讀 49,144評(píng)論 1 285
  • 那天他宛,我揣著相機(jī)與錄音,去河邊找鬼欠气。 笑死厅各,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的预柒。 我是一名探鬼主播队塘,決...
    沈念sama閱讀 38,432評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼宜鸯!你這毒婦竟也來了憔古?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,088評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤淋袖,失蹤者是張志新(化名)和其女友劉穎鸿市,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體即碗,經(jīng)...
    沈念sama閱讀 43,586評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡焰情,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,028評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了剥懒。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片内舟。...
    茶點(diǎn)故事閱讀 38,137評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖初橘,靈堂內(nèi)的尸體忽然破棺而出验游,到底是詐尸還是另有隱情充岛,我是刑警寧澤,帶...
    沈念sama閱讀 33,783評(píng)論 4 324
  • 正文 年R本政府宣布批狱,位于F島的核電站裸准,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏赔硫。R本人自食惡果不足惜炒俱,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,343評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望爪膊。 院中可真熱鬧权悟,春花似錦、人聲如沸推盛。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽耘成。三九已至榔昔,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間瘪菌,已是汗流浹背撒会。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評(píng)論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留师妙,地道東北人诵肛。 一個(gè)月前我還...
    沈念sama閱讀 45,595評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像默穴,于是被迫代替她去往敵國和親怔檩。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,901評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 一. 垃圾回收的意義 在C++中蓄诽,對(duì)象所占的內(nèi)存在程序結(jié)束運(yùn)行之前一直被占用薛训,在明確釋放之前不能分配給其它對(duì)...
    Stan_Z閱讀 1,921評(píng)論 0 25
  • 原文閱讀 前言 這段時(shí)間懈怠了,罪過仑氛! 最近看到有同事也開始用上了微信公眾號(hào)寫博客了许蓖,挺好的~給他們點(diǎn)贊,這博客我...
    碼農(nóng)戲碼閱讀 5,948評(píng)論 2 31
  • 這篇文章是我之前翻閱了不少的書籍以及從網(wǎng)絡(luò)上收集的一些資料的整理调衰,因此不免有一些不準(zhǔn)確的地方膊爪,同時(shí)不同JDK版本的...
    高廣超閱讀 15,545評(píng)論 3 83
  • 1.什么是垃圾回收? 垃圾回收(Garbage Collection)是Java虛擬機(jī)(JVM)垃圾回收器提供...
    簡欲明心閱讀 89,409評(píng)論 17 311
  • JVM架構(gòu) 當(dāng)一個(gè)程序啟動(dòng)之前嚎莉,它的class會(huì)被類裝載器裝入方法區(qū)(Permanent區(qū))米酬,執(zhí)行引擎讀取方法區(qū)的...
    cocohaifang閱讀 1,648評(píng)論 0 7