您好,登錄后才能下訂單哦!
之前寫過的一篇Java垃圾回收之標記清除算法詳解 ,這個算法有個缺點就是造成內(nèi)存碎片,存在不連續(xù)的空間,這樣會導致申請較大空間的時候,又需要進行垃圾回收。下面介紹一下標記壓縮算法,可以避免內(nèi)存碎片。
空白部分是不連續(xù)的。
概述
這個算法的標記清除階段,跟Java垃圾回收之標記清除算法詳解 中的是一樣的,而對于壓縮階段,它的工作就是移動所有的可達對象到堆內(nèi)存的同一個區(qū)域中,使他們緊湊的排列在一起,從而將所有非可達對象釋放出來的空閑內(nèi)存都集中在一起,通過這樣的方式來達到減少內(nèi)存碎片的目的。如下圖:
壓縮算法簡單介紹
優(yōu)點
解決內(nèi)存碎片問題。
缺點
壓縮階段,由于移動了可用對象,需要去更新引用。
總結
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關內(nèi)容請查看下面相關鏈接
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。