1、引用強度排序html
強引用>軟引用>弱引用>虛引用緩存
2、強引用:htm
1. 正常建立的對象,只要引用存在,永遠不會被GC回收,即便OOM對象
Object obj = new Object();blog
2. 若是要中斷強引用和某個對象的關聯,爲其賦值null,這樣GC就會在合適的時候回收對象排序
3. Vector類的clear()方法就是經過賦值null進行清除隊列
3、軟引用內存
1. 內存溢出以前進行回收,GC時內存不足時回收,若是內存足夠就不回收get
2. 使用場景:在內存足夠的狀況下進行緩存,提高速度,內存不足時JVM自動回收監控
Object obj = new Object();
SoftReference<Object> sf = new SoftReference<Object>(obj);
sf.get();//有時候會返回null
3. 能夠和引用隊列ReferenceQueue聯合使用,若是軟引用所引用的對象被JVM回收,這個軟引用就會被加入到與之關聯的引用隊列中
4、弱引用
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回收,這個軟引用就會被加入到與之關聯的引用隊列中
5、虛引用
1. 每次垃圾回收時都會被回收,主要用於監測對象是否已經從內存中刪除
2. 虛引用必須和引用隊列關聯使用, 當垃圾回收器準備回收一個對象時,若是發現它還有虛引用,就會把這個虛引用加入到與之 關聯的引用隊列中
3. 程序能夠經過判斷引用隊列中是否已經加入了虛引用,來了解被引用的對象是否將要被垃圾回收。若是程序發現某個虛引用已經被加入到引用隊列,那麼就能夠在所引用的對象的內存被回收以前採起必要的行動
Object obj = new Object();
PhantomReference<Object> pf = new PhantomReference<Object>(obj);
obj=null;
pf.get();//永遠返回null
pf.isEnQueued();//返回是否從內存中已經刪除
參考: