強引用、軟引用、弱引用、虛引用總結


總結:
強引用:普通new對象的引用
User user = new User();
jvm寧願拋出OutOfMemory異常也不會去回收該對象
軟引用
SoftReference引用的裝飾的對象,該對象的強引用應該賦值空
這里配合ReferenceQueue使用(也可以不配合),因為SoftReference本身也是new了一個對象
當他把別人的問題解決掉以后,也需要把自己的問題解決,所以當jvm把軟引用
對象回收后,就會把自己的對象引用放到這個隊列中,我們可以通過隊列的poll()
方法查看,如果存在該ReferenceQueue,那么就說明該對象的軟引用對象已經被jvm
回收,我們需要將該ReferenceQueue引用也賦值為空,等待被jvm回收。
注意:軟引用對象是在jvm內存不夠的時候才會被回收,我們調用System.gc()方法只是
起通知作用,jvm什么時候掃描回收對象是,是jvm自己的狀態決定的。就算掃描到軟引用
對象也不一定會回收它。只有內存不夠的時候才會回收

ReferenceQueue queue = new ReferenceQueue();
User user = new User();
SoftReference ref=new SoftReference(user, queue);
user=null;

弱引用:弱引用也是用來描述非必需對象的,當JVM進行垃圾回收時,只要掃描到,
無論內存是否充足(與軟引用的區別),都會回收被弱引用關聯的對象。在java中,
用java.lang.ref.WeakReference類來表示
WeakReference<User> sr = new WeakReference<User>(new User());
System.out.println(sr.get());
System.gc(); //通知JVM的gc進行垃圾回收
System.out.println(sr.get());

虛引用
虛引用和前面的軟引用、弱引用不同,它並不影響對象的生命周期。
在java中用java.lang.ref.PhantomReference類表示。如果一個對象與虛引用關聯,
則跟沒有引用與之關聯一樣,在任何時候都可能被垃圾回收器回收。
要注意的是,虛引用必須和引用隊列關聯使用,當垃圾回收器准備回收一個對象時,
如果發現它還有虛引用,就會把這個虛引用加入到與之 關聯的引用隊列中。
程序可以通過判斷引用隊列中是否已經加入了虛引用,來了解被引用的對象是否將要被垃圾回收。
如果程序發現某個虛引用已經被加入到引用隊列,那么就可以在所引用的對象的內存被回收之前采取必要的行動。
ReferenceQueue queue = new ReferenceQueue();
PhantomReference<User> pr = new PhantomReference<User>(new User(), queue);
System.out.println(pr.get());


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM