您好,登錄后才能下訂單哦!
本篇內容介紹了“Java中的引用知識點總結”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
強引用:默認情況下,對象采用的均為強引用(這個對象的實例沒有其他對象引用,GC時才會被回收)
軟引用:軟引用是Java中提供的一種比較適合于緩存場景的應用(只有在內存不夠用的情況下才會被GC)
弱引用:在GC時一定會被GC回收
虛引用:由于虛引用只是用來得知對象是否被GC
強引用是使用最普遍的引用。如果一個對象具有強引用,那垃圾回收器絕不會回收它。如下:
Object strongReference = new Object();
當內存空間不足時,Java虛擬機寧愿拋出OutOfMemoryError錯誤,使程序異常終止,也不會靠隨意回收具有強引用的對象來解決內存不足的問題。 如果強引用對象不使用時,需要弱化從而使GC能夠回收,如下:
strongReference = null;
顯式地設置strongReference對象為null,或讓其超出對象的生命周期范圍,則gc認為該對象不存在引用,這時就可以回收這個對象。具體什么時候收集這要取決于GC算法。
如果一個對象只具有軟引用,則內存空間充足時,垃圾回收器就不會回收它;如果內存空間不足了,就會回收這些對象的內存。只要垃圾回收器沒有回收它,該對象就可以被程序使用。
軟引用可用來實現內存敏感的高速緩存。
// 軟引用 String str = new String("abc"); SoftReference<String> softReference = new SoftReference<String>(str);
當內存不足時,JVM首先將軟引用中的對象引用置為null,然后通知垃圾回收器進行回收:
if(JVM內存不足) { // 將軟引用中的對象引用置為null str = null; // 通知垃圾回收器進行回收 System.gc(); }
也就是說,垃圾收集線程會在虛擬機拋出OutOfMemoryError之前回收軟引用對象,而且虛擬機會盡可能優先回收長時間閑置不用的軟引用對象。對那些剛構建的或剛使用過的“較新的”軟對象會被虛擬機盡可能保留,這就是引入引用隊列ReferenceQueue的原因。
應用場景:
瀏覽器的后退按鈕。按后退時,這個后退時顯示的網頁內容是重新進行請求還是從緩存中取出呢?這就要看具體的實現策略了。
如果一個網頁在瀏覽結束時就進行內容的回收,則按后退查看前面瀏覽過的頁面時,需要重新構建;
如果將瀏覽過的網頁存儲到內存中會造成內存的大量浪費,甚至會造成內存溢出。
這時候就可以使用軟引用,很好的解決了實際的問題:
// 獲取瀏覽器對象進行瀏覽 Browser browser = new Browser(); // 從后臺程序加載瀏覽頁面 BrowserPage page = browser.getPage(); // 將瀏覽完畢的頁面置為軟引用 SoftReference softReference = new SoftReference(page); // 回退或者再次瀏覽此頁面時 if(softReference.get() != null) { // 內存充足,還沒有被回收器回收,直接獲取緩存 page = softReference.get(); } else { // 內存不足,軟引用的對象已經回收 page = browser.getPage(); // 重新構建軟引用 softReference = new SoftReference(page); }
弱引用與軟引用的區別在于:只具有弱引用的對象擁有更短暫的生命周期。在垃圾回收器線程掃描它所管轄的內存區域的過程中,一旦發現了只具有弱引用的對象,不管當前內存空間足夠與否,都會回收它的內存。不過,由于垃圾回收器是一個優先級很低的線程,因此不一定會很快發現那些只具有弱引用的對象。
String str = new String("abc"); WeakReference<String> weakReference = new WeakReference<>(str); str = null;
如果一個對象是偶爾(很少)的使用,并且希望在使用時隨時就能獲取到,但又不想影響此對象的垃圾收集,那么你應該用Weak Reference來記住此對象。一個使用弱引用的例子是WeakHashMap,它是除HashMap和TreeMap之外,Map接口的另一種實現。WeakHashMap有一個特點:map中的鍵值(keys)都被封裝成弱引用,也就是說一旦強引用被刪除,WeakHashMap內部的弱引用就無法阻止該對象被垃圾回收器回收。
下面的代碼會讓一個弱引用再次變為一個強引用:
String str = new String("abc"); WeakReference<String> weakReference = new WeakReference<>(str); // 弱引用轉強引用 String strongReference = weakReference.get();
Threadlocal中的ThreadLocalMap的成員變量,ThreadLocalMap 內部采用WeakReference數組保存,數組的key即為ThreadLocal 內部的Hash值。
虛引用顧名思義,就是形同虛設。與其他幾種引用都不同,虛引用并不會決定對象的生命周期。如果一個對象僅持有虛引用,那么它就和沒有任何引用一樣,在任何時候都可能被垃圾回收器回收。
應用場景:
虛引用主要用來跟蹤對象被垃圾回收器回收的活動。 虛引用與軟引用和弱引用的一個區別在于:
虛引用必須和引用隊列(ReferenceQueue)聯合使用。當垃圾回收器準備回收一個對象時,如果發現它還有虛引用,就會在回收對象的內存之前,把這個虛引用加入到與之關聯的引用隊列中。
String str = new String("abc"); ReferenceQueue queue = new ReferenceQueue(); // 創建虛引用,要求必須與一個引用隊列關聯 PhantomReference pr = new PhantomReference(str, queue);程序可以通過判斷引用隊列中是否已經加入了虛引用,來了解被引用的對象是否將要進行垃圾回收。如果程序發現某個虛引用已經被加入到引用隊列,那么就可以在所引用的對象的內存被回收之前采取必要的行動。
“Java中的引用知識點總結”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。