java中g(shù)c算法實(shí)例用法
在我們對gc中的算法有基本概念理解后,要把算法的理念實(shí)現(xiàn)還需要依托實(shí)際垃圾收集器的使用。因?yàn)楣饪恳恍┖唵蔚脑聿蛔阋灾握麄€程序的運(yùn)行,在回收機(jī)制上有專門的收集器。下面我們就垃圾收集器的概念、使用注意事項(xiàng)、收集器圖解進(jìn)行介紹,然后帶來兩種常見的垃圾收集器供大家參考。
1.概念
垃圾收集器時之前列舉的垃圾收集算法的具體實(shí)現(xiàn)。
2.注意事項(xiàng)
每一個回收器都存在Stop The World 的問題,只不過各個回收器在Stop The World 時間優(yōu)化程度、算法的不同,可根據(jù)自身需求選擇適合的回收器。
3.垃圾收集器圖解
上圖是經(jīng)典的幾個垃圾收集器,上面屬于新生代,下面屬于老年代,而其中G1的內(nèi)存劃分不是依據(jù)新生代和老年代來劃分的。
兩個重要概念:
并行:垃圾收集器可以開啟多個垃圾收集線程并行進(jìn)行標(biāo)記、清理等處理。
并發(fā):垃圾收集器的標(biāo)記、清理線程和用戶線程同時運(yùn)行。
4.常見垃圾收集器
(1) Serial收集器
Serial收集器作用于新生代,是一個單線程收集器,基于復(fù)制算法實(shí)現(xiàn)。在進(jìn)行垃圾回收的時候僅使用單條線程并且在回收的過程中會掛起所有的用戶線程(Stop The World)。Serial收集器是JVM client模式下默認(rèn)的新生代收集器。
(2)ParNew收集器
新生代收集器,Serial的多線程并行版本,行為與Serial一致,同時使用多條垃圾收集線程進(jìn)行垃圾收集。
特點(diǎn):除了Serial收集器外,只有它能與CMS收集器配合工作。
知識點(diǎn)擴(kuò)展:
引用計(jì)數(shù)法 Reference Counting
給對象添加一個引用計(jì)數(shù)器,每過一個引用計(jì)數(shù)器值就+1,少一個引用就-1。當(dāng)它的引用變?yōu)?時,該對象就不能再被使用。它的實(shí)現(xiàn)簡單,但是不能解決互相循環(huán)引用的問題。
根搜索算法 GC Roots Tracing
以一系列叫“GC Roots”的對象為起點(diǎn)開始向下搜索,走過的路徑稱為引用鏈(Reference Chain),當(dāng)一個對象沒有和任何引用鏈相連時,證明此對象是不可用的,用圖論的說法是不可達(dá)的。那么它就會被判定為是可回收的對象。
JAVA里可作為GC Roots的對象
虛擬機(jī)棧(棧幀中的本地變量表)中引用的對象
方法區(qū)中的類靜態(tài)屬性引用的對象
方法區(qū)中的常量引用的對象
本地方法棧中JNI(即Native方法)的引用的對象
標(biāo)記-清除算法 Mark-Sweep
這是一個非?;镜腉C算法,它是現(xiàn)代GC算法的思想基礎(chǔ),分為標(biāo)記和清除兩個階段:先把所有活動的對象標(biāo)記出來,然后把沒有被標(biāo)記的對象統(tǒng)一清除掉。但是它有兩個問題,一是效率問題,兩個過程的效率都不高。二是空間問題,清除之后會產(chǎn)生大量不連續(xù)的內(nèi)存。
復(fù)制算法 Copying
復(fù)制算法是將原有的內(nèi)存空間分成兩塊,每次只使用其中的一塊。在GC時,將正在使用的內(nèi)存塊中的存活對象復(fù)制到未使用的那一塊中,然后清除正在使用的內(nèi)存塊中的所有對象,并交換兩塊內(nèi)存的角色,完成一次垃圾回收。它比標(biāo)記-清除算法要高效,但不適用于存活對象較多的內(nèi)存,因?yàn)閺?fù)制的時候會有較多的時間消耗。它的致命缺點(diǎn)是會有一半的內(nèi)存浪費(fèi)。
標(biāo)記整理算法 Mark-Compact
標(biāo)記整理算法適用于存活對象較多的場合,它的標(biāo)記階段和標(biāo)記-清除算法中的一樣。整理階段是將所有存活的對象壓縮到內(nèi)存的一端,之后清理邊界外所有的空間。它的效率也不高。
相關(guān)文章
java創(chuàng)建excel示例(jxl使用方法)
Java Excel是一開放源碼項(xiàng)目,通過它Java開發(fā)人員可以讀取Excel文件的內(nèi)容、創(chuàng)建新的Excel文件、更新 已經(jīng)存在的Excel文件。下面是使用方法,包括去掉網(wǎng)格線、字體設(shè)置、單元格設(shè)置、對齊方式等設(shè)置2014-03-03SpringBoot+OCR實(shí)現(xiàn)PDF內(nèi)容識別的示例代碼
在SpringBoot中,您可以結(jié)合OCR庫來實(shí)現(xiàn)對PDF文件內(nèi)容的識別和提取,本文就來介紹一下如何使用 Tesseract 和 pdf2image 對 PDF 文件進(jìn)行OCR識別和提取,具有一定的參考價值,感興趣的可以了解一下2023-12-12Javaweb開發(fā)環(huán)境Myeclipse6.5 JDK1.6 Tomcat6.0 SVN1.8配置教程
這篇文章主要介紹了Javaweb開發(fā)環(huán)境Myeclipse6.5 JDK1.6 Tomcat6.0 SVN1.8配置教程,感興趣的小伙伴們可以參考一下2016-06-06mybatis實(shí)現(xiàn)mapper代理模式的方式
本文向大家講解mybatis的mapper代理模式,以根據(jù)ide值查詢單條數(shù)據(jù)為例編寫xml文件,通過mapper代理的方式進(jìn)行講解增刪改查,分步驟給大家講解的很詳細(xì),對mybatis mapper代理模式相關(guān)知識感興趣的朋友一起看看吧2021-06-06JAVA簡單實(shí)現(xiàn)MD5注冊登錄加密實(shí)例代碼
本篇文章主要介紹了JAVA簡單實(shí)現(xiàn)MD5注冊登錄加密實(shí)例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03java swing 創(chuàng)建一個簡單的QQ界面教程
這篇文章主要介紹了java swing 創(chuàng)建一個簡單的QQ界面教程,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09