Java垃圾回收之標(biāo)記壓縮算法詳解
之前寫過的一篇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ì)象釋放出來的空閑內(nè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ì)象原來在堆中的順序滑動(dòng)到堆的一端。
優(yōu)點(diǎn)
解決內(nèi)存碎片問題。
缺點(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)文章
SpringBoot上傳文件到本服務(wù)器 目錄與jar包同級(jí)問題
這篇文章主要介紹了SpringBoot上傳文件到本服務(wù)器 目錄與jar包同級(jí)問題,需要的朋友可以參考下2018-11-11
Mybatis 動(dòng)態(tài)SQL的幾種實(shí)現(xiàn)方法
這篇文章主要介紹了Mybatis 動(dòng)態(tài)SQL的幾種實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
解決@SpringBootTest 單元測(cè)試遇到的坑
這篇文章主要介紹了解決@SpringBootTest 單元測(cè)試遇到的坑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10
JAVA導(dǎo)出EXCEL表格的實(shí)例教學(xué)
在本文中我們給大家整理了關(guān)于JAVA導(dǎo)出EXCEL表格的實(shí)例教學(xué)以及相關(guān)知識(shí)點(diǎn),需要的朋友們學(xué)習(xí)下。2019-02-02
Vue中computed計(jì)算屬性和data數(shù)據(jù)獲取方式
這篇文章主要介紹了Vue中computed計(jì)算屬性和data數(shù)據(jù)獲取方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
spring boot使用logback日志級(jí)別打印控制操作
這篇文章主要介紹了spring boot使用logback日志級(jí)別打印控制操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-03-03
Java多線程編程實(shí)現(xiàn)socket通信示例代碼
這篇文章主要介紹了Java多線程編程實(shí)現(xiàn)socket通信示例代碼,詳細(xì)介紹了tcp、udp協(xié)議,以及基于socket的Java網(wǎng)絡(luò)編程的相關(guān)內(nèi)容及代碼示例,代碼測(cè)試可用,供大家參考。2017-10-10

