一、引用強度排序
強引用>軟引用>弱引用>虛引用
二、強引用:
1. 正常創建的對象,只要引用存在,永遠不會被GC回收,即使OOM
Object obj = new Object();
2. 如果要中斷強引用和某個對象的關聯,為其賦值null,這樣GC就會在合適的時候回收對象
3. Vector類的clear()方法就是通過賦值null進行清除
三、軟引用
1. 內存溢出之前進行回收,GC時內存不足時回收,如果內存足夠就不回收
2. 使用場景:在內存足夠的情況下進行緩存,提升速度,內存不足時JVM自動回收
Object obj = new Object();
SoftReference<Object> sf = new SoftReference<Object>(obj);
sf.get();//有時候會返回null
3. 可以和引用隊列ReferenceQueue聯合使用,如果軟引用所引用的對象被JVM回收,這個軟引用就會被加入到與之關聯的引用隊列中
四、弱引用
1. 每次GC時回收,無論內存是否足夠
2. 使用場景:a. ThreadLocalMap防止內存泄漏 b. 監控對象是否將要被回收
Object obj = new Object();
WeakReference<Object> wf = new WeakReference<Object>(obj);
wf.get();//有時候會返回null
wf.isEnQueued();//返回是否被垃圾回收器標記為即將回收的垃圾
System.gc(); //通知JVM的gc進行垃圾回收,但JVM不一定會立刻執行
wf.get();//此時會返回null
3. 弱引用可以和一個引用隊列(ReferenceQueue)聯合使用,如果弱引用所引用的對象被JVM回收,這個軟引用就會被加入到與之關聯的引用隊列中
五、虛引用
1. 每次垃圾回收時都會被回收,主要用於監測對象是否已經從內存中刪除
2. 虛引用必須和引用隊列關聯使用, 當垃圾回收器准備回收一個對象時,如果發現它還有虛引用,就會把這個虛引用加入到與之 關聯的引用隊列中
3. 程序可以通過判斷引用隊列中是否已經加入了虛引用,來了解被引用的對象是否將要被垃圾回收。如果程序發現某個虛引用已經被加入到引用隊列,那么就可以在所引用的對象的內存被回收之前采取必要的行動
Object obj = new Object();
PhantomReference<Object> pf = new PhantomReference<Object>(obj);
obj=null;
pf.get();//永遠返回null
pf.isEnQueued();//返回是否從內存中已經刪除
參考:
https://www.cnblogs.com/yw-ah/p/5830458.html
https://www.cnblogs.com/dolphin0520/p/3784171.html