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