您好,登錄后才能下訂單哦!
本篇內容主要講解“怎么使用Java垃圾回收算法”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“怎么使用Java垃圾回收算法”吧!
引用計數法:在Java中,引用和對象是有關聯的。如果要操作對象則必須用引用進行。因此,很顯然一個簡單的辦法是通過引用計數來判斷一個對象是否可以回收。簡單說,即一個對象如果沒有任何與之關聯的引用,即他們的引用計數都不為0,則說明對象不太可能再被用到,那么這個對象就是可回收對象。
可達性分析:為了解決引用計數法的循環引用問題,Java使用了可達性分析的方法。通過一系列“GC roots”對象作為起點搜索。如果在“GC roots”和一個對象之間沒有可達路徑,則稱該對象是不可達的。要注意的是,不可達對象不等價于可回收對象,不可達對象變為可回收對象至少要經過兩次標記過程。兩次標記后仍然是可回收對象,則將面臨回收。
垃圾回收算法
標記清除算法(Mark-Sweep)最基礎的垃圾回收算法,分為兩個階段,標注和清除。標記階段標記出所有需要回收的對象,清除階段回收被標記的對象所占用的空間。該算法最大的問題是內存碎片化嚴重,后續可能發生大對象不能找到可利用空間的問題。
復制算法(copying)為了解決Mark-Sweep 算法內存碎片化的缺陷而被提出的算法。按內存容量將內存劃分為等大小的兩塊。每次只使用其中一塊,當這一塊內存滿后將尚存活的對象復制到另一塊上去,把已使用的內存清掉。這種算法雖然實現簡單,內存效率高,不易產生碎片,但是最大的問題是可用內存被壓縮到了原本的一半。且存活對象增多的話,Copying 算法的效率會大大降低。
分代收集算法分代收集法是目前大部分JVM所采用的方法,其核心思想是根據對象存活的不同生命周期將內存劃分為不同的域,一般情況下將GC堆劃分為老生代(Tenured/Old Generation)和新生代(Young Generation)。老生代的特點是每次垃圾回收時只有少量對象需要被回收,新生代的特點是每次垃圾回收時都有大量垃圾需要被回收,因此可以根據不同區域選擇不同的算法。
新生代與復制算法
目前大部分JVM的GC對于新生代都采取Copying算法,因為新生代中每次垃圾回收都要回收大部分對象,即要復制的操作比較少,但通常并不是按照1:1來劃分新生代。一般將新生代劃分為一塊較大的Eden空間和兩個較小的Survivor空間(From Space, To Space),每次使用Eden空間和其中的一塊Survivor空間,當進行回收時,將該兩塊空間中還存活的對象復制到另一塊Survivor空間中。
老年代與標記復制算法
老年代因為每次只回收少量對象,因而采用Mark-Compact算法。
(1)Java虛擬機提到過的處于方法區的永生代(Permanet Generation),它用來存儲class類,常量,方法描述等。對永生代的回收主要包括廢棄常量和無用的類。
(2)對象的內存分配主要在新生代的Eden Space和Survivor Space的From Space(Survivor 目前存放對象的那一塊),少數情況會直接分配到老生代。
(3)當新生代的Eden Space和 From Space空間不足時就會發生一次GC,進行GC后,Eden Space和From Space區的存活對象會被挪到To Space,然后將Eden Space和From Space進行清理。
(4)如果To Space無法足夠存儲某個對象,則將這個對象存儲到老生代。
(5)在進行GC后,使用的便是Eden Space和To Space了,如此反復循環。
(6)當對象在Survivor區躲過一次GC后,其年齡就會+1。默認情況下年齡到達15的對象會被移到老生代中。
到此,相信大家對“怎么使用Java垃圾回收算法”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。