Java垃圾回收之標(biāo)記壓縮算法詳解
之前寫(xiě)過(guò)的一篇Java垃圾回收之標(biāo)記清除算法詳解 ,這個(gè)算法有個(gè)缺點(diǎn)就是造成內(nèi)存碎片,存在不連續(xù)的空間,這樣會(huì)導(dǎo)致申請(qǐng)較大空間的時(shí)候,又需要進(jìn)行垃圾回收。下面介紹一下標(biāo)記壓縮算法,可以避免內(nèi)存碎片。
空白部分是不連續(xù)的。
概述
這個(gè)算法的標(biāo)記清除階段,跟Java垃圾回收之標(biāo)記清除算法詳解 中的是一樣的,而對(duì)于壓縮階段,它的工作就是移動(dòng)所有的可達(dá)對(duì)象到堆內(nèi)存的同一個(gè)區(qū)域中,使他們緊湊的排列在一起,從而將所有非可達(dá)對(duì)象釋放出來(lái)的空閑內(nèi)存都集中在一起,通過(guò)這樣的方式來(lái)達(dá)到減少內(nèi)存碎片的目的。如下圖:
壓縮算法簡(jiǎn)單介紹
- 任意順序 : 即不考慮原先對(duì)象的排列順序,也不考慮對(duì)象之間的引用關(guān)系,隨意移動(dòng)對(duì)象;
- 線性順序 : 考慮對(duì)象的引用關(guān)系,例如a對(duì)象引用了b對(duì)象,則盡可能將a和b移動(dòng)到一塊;
- 滑動(dòng)順序 : 按照對(duì)象原來(lái)在堆中的順序滑動(dòng)到堆的一端。
優(yōu)點(diǎn)
解決內(nèi)存碎片問(wèn)題。
缺點(diǎn)
壓縮階段,由于移動(dòng)了可用對(duì)象,需要去更新引用。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
深入詳解Java中synchronized鎖升級(jí)的套路
synchronized鎖是啥?鎖其實(shí)就是一個(gè)對(duì)象,隨便哪一個(gè)都可以,Java中所有的對(duì)象都是鎖,換句話說(shuō),Java中所有對(duì)象都可以成為鎖。本文我們主要來(lái)聊聊synchronized鎖升級(jí)的套路,感興趣的可以收藏一下2023-04-04Java使用Sftp和Ftp實(shí)現(xiàn)對(duì)文件的上傳和下載
這篇文章主要介紹了Java使用Sftp和Ftp實(shí)現(xiàn)對(duì)文件的上傳和下載,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03Mapstruct?@Mapper?@Mapping?使用小結(jié)
這篇文章主要介紹了Mapstruct?@Mapper?@Mapping使用小結(jié),他們用于各個(gè)對(duì)象實(shí)體間的相互轉(zhuǎn)換,例如數(shù)據(jù)庫(kù)底層實(shí)體轉(zhuǎn)為頁(yè)面對(duì)象,Model?轉(zhuǎn)為?DTO,?DTO?轉(zhuǎn)為其他中間對(duì)象,?VO?等等,相關(guān)轉(zhuǎn)換代碼為編譯時(shí)自動(dòng)產(chǎn)生的新文件和代碼,需要的朋友可以參考下2023-09-09SpringBoot動(dòng)態(tài)數(shù)據(jù)源連接測(cè)試的操作詳解
這篇文章主要介紹了SpringBoot動(dòng)態(tài)數(shù)據(jù)源連接測(cè)試的操作步驟,文中通過(guò)代碼示例和圖文結(jié)合的方式給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-03-03JDK13.0.1安裝與環(huán)境變量的配置教程圖文詳解(Win10平臺(tái)為例)
這篇文章主要介紹了JDK13.0.1安裝與環(huán)境變量的配置教程圖文詳解(Win10平臺(tái)為例),本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-01-01Spring?Boot2.6.0新特性之默認(rèn)禁止循環(huán)引用
Spring?Boot2.6.0為我們帶來(lái)很多好用的新特性/改進(jìn),這篇文章主要給大家介紹了關(guān)于Spring?Boot2.6.0新特性之默認(rèn)禁止循環(huán)引用的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-02-02Java數(shù)據(jù)結(jié)構(gòu)之圖的原理與實(shí)現(xiàn)
圖(Graph)是由頂點(diǎn)的有窮非空集合和頂點(diǎn)之間邊的集合組成,通常表示為:G(V,E),其中,G表示一個(gè)圖,V是圖G中頂點(diǎn)的集合,E是圖G中邊的集合。本文將詳細(xì)介紹圖的原理及其代碼實(shí)現(xiàn),需要的可以參考一下2022-01-01使用ClassFinal實(shí)現(xiàn)SpringBoot項(xiàng)目jar包加密的操作指南
在實(shí)際開(kāi)發(fā)中,保護(hù)項(xiàng)目的安全性和保密性是至關(guān)重要的,針對(duì)于 Spring Boot 項(xiàng)目,我們需要將 JAR 包進(jìn)行加密從而有效地防止未經(jīng)授權(quán)的訪問(wèn)和修改,本文將介紹如何使用ClassFinal在 Spring Boot 項(xiàng)目中實(shí)現(xiàn) JAR 包加密,需要的朋友可以參考下2024-06-06