1.強引用(StrongReference)
- 使用最普遍的引用。
-
只要引用鏈沒有斷開,強引用就不會斷開。- 當內存空間不足,拋出
OutOfMemoryError
終止程序也不會回收具有強引用的對象。 - 通過將對象設置為null來弱化引用,使其被回收
1
2
3
|
Object object = new Object(); String str = "scc" ; //都是強引用 |
2.軟引用(SoftReference)
- 對象處在有用但非必須的狀態
- 只有當內存空間不足時, GC會回收該引用的對象的內存。
- 可以用來實現高速緩存(作用)--比如網頁緩存、圖片緩存
1
2
3
|
// 注意:wrf這個引用也是強引用,它是指向SoftReference這個對象的, // 這里的軟引用指的是指向new String("str")的引用,也就是SoftReference類中T SoftReference<String> wrf = new SoftReference<String>( new String( "str" )); |
3.弱引用(WeakReference)
弱引用就是只要JVM垃圾回收器發現了它,就會將之回收。
- 非必須的對象,比軟引用更弱一-些
- GC時會被回
- 被回收的概率也不大,因為GC線程優先級比較低
- 適用于引用偶爾被使用且不影響垃圾收集的對象 使用:
1
2
|
Map<Key, ResourceWeakReference> activeEngineResources = new HashMap<>(); //ResourceWeakReference弱引用 |
4.虛引用(PhantomReference)
- 不會決定對象的生命周期
- 任何時候都可能被垃圾收集器回收
- 跟蹤對象被垃圾收集器回收的活動,起哨兵作用
-
必須和引用隊列
ReferenceQueue
聯合使用
當垃圾回收器準備回收一個對象時,如果發現它還有虛引用,就會把這個虛引用加入到與之 關聯的引用隊列中。
程序可以通過判斷引用隊列中是否已經加入了虛引用,來了解被引用的對象是否將要被垃圾回收。如果程序發現某個虛引用已經被加入到引用隊列,那么就可以在所引用的對象的內存被回收之前采取必要的行動。
1
2
3
4
5
|
Object obj = new Object(); ReferenceQueue queue = new ReferenceQueue(); PhantomReference reference = new PhantomReference(obj, queue); //強引用對象滯空,保留軟引用 obj = null ; |
5. 引用隊列(ReferenceQueue)
- 無實際存儲結構,存儲邏輯依賴于內部節點之間的關系來表達
- 存儲關聯的且被GC的軟引用,弱引用以及虛引用
