溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java垃圾回收之標記壓縮算法詳解

發(fā)布時間:2020-10-23 04:27:03 來源:腳本之家 閱讀:238 作者:Sam哥哥 欄目:編程語言

之前寫過的一篇Java垃圾回收之標記清除算法詳解 ,這個算法有個缺點就是造成內(nèi)存碎片,存在不連續(xù)的空間,這樣會導致申請較大空間的時候,又需要進行垃圾回收。下面介紹一下標記壓縮算法,可以避免內(nèi)存碎片。

Java垃圾回收之標記壓縮算法詳解

空白部分是不連續(xù)的。

概述

這個算法的標記清除階段,跟Java垃圾回收之標記清除算法詳解  中的是一樣的,而對于壓縮階段,它的工作就是移動所有的可達對象到堆內(nèi)存的同一個區(qū)域中,使他們緊湊的排列在一起,從而將所有非可達對象釋放出來的空閑內(nèi)存都集中在一起,通過這樣的方式來達到減少內(nèi)存碎片的目的。如下圖:

Java垃圾回收之標記壓縮算法詳解

壓縮算法簡單介紹

  • 任意順序 : 即不考慮原先對象的排列順序,也不考慮對象之間的引用關系,隨意移動對象;
  • 線性順序 : 考慮對象的引用關系,例如a對象引用了b對象,則盡可能將a和b移動到一塊;
  • 滑動順序 : 按照對象原來在堆中的順序滑動到堆的一端。

優(yōu)點

解決內(nèi)存碎片問題。

缺點

壓縮階段,由于移動了可用對象,需要去更新引用。

總結

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關內(nèi)容請查看下面相關鏈接

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI