中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java中的引用知識點總結

發布時間:2021-08-21 19:52:26 來源:億速云 閱讀:123 作者:chen 欄目:軟件技術

本篇內容介紹了“Java中的引用知識點總結”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

  • 強引用:默認情況下,對象采用的均為強引用(這個對象的實例沒有其他對象引用,GC時才會被回收)

  • 軟引用:軟引用是Java中提供的一種比較適合于緩存場景的應用(只有在內存不夠用的情況下才會被GC)

  • 弱引用:在GC時一定會被GC回收

  • 虛引用:由于虛引用只是用來得知對象是否被GC

一. 強引用(StrongReference)

強引用是使用最普遍的引用。如果一個對象具有強引用,那垃圾回收器絕不會回收它。如下:

Object strongReference = new Object();

當內存空間不足時,Java虛擬機寧愿拋出OutOfMemoryError錯誤,使程序異常終止,也不會靠隨意回收具有強引用的對象來解決內存不足的問題。 如果強引用對象不使用時,需要弱化從而使GC能夠回收,如下:

strongReference = null;

顯式地設置strongReference對象為null,或讓其超出對象的生命周期范圍,則gc認為該對象不存在引用,這時就可以回收這個對象。具體什么時候收集這要取決于GC算法。

二. 軟引用(SoftReference)

如果一個對象只具有軟引用,則內存空間充足時,垃圾回收器就不會回收它;如果內存空間不足了,就會回收這些對象的內存。只要垃圾回收器沒有回收它,該對象就可以被程序使用。

軟引用可用來實現內存敏感的高速緩存。

// 軟引用
    String str = new String("abc");
    SoftReference<String> softReference = new SoftReference<String>(str);

當內存不足時,JVM首先將軟引用中的對象引用置為null,然后通知垃圾回收器進行回收:

if(JVM內存不足) {
        // 將軟引用中的對象引用置為null
        str = null;
        // 通知垃圾回收器進行回收
        System.gc();
    }

也就是說,垃圾收集線程會在虛擬機拋出OutOfMemoryError之前回收軟引用對象,而且虛擬機會盡可能優先回收長時間閑置不用的軟引用對象。對那些剛構建的或剛使用過的“較新的”軟對象會被虛擬機盡可能保留,這就是引入引用隊列ReferenceQueue的原因。

應用場景

瀏覽器的后退按鈕。按后退時,這個后退時顯示的網頁內容是重新進行請求還是從緩存中取出呢?這就要看具體的實現策略了。

  1. 如果一個網頁在瀏覽結束時就進行內容的回收,則按后退查看前面瀏覽過的頁面時,需要重新構建;

  2. 如果將瀏覽過的網頁存儲到內存中會造成內存的大量浪費,甚至會造成內存溢出。

這時候就可以使用軟引用,很好的解決了實際的問題:

// 獲取瀏覽器對象進行瀏覽
    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);
    }

三. 弱引用(WeakReference)

弱引用與軟引用的區別在于:只具有弱引用的對象擁有更短暫的生命周期。在垃圾回收器線程掃描它所管轄的內存區域的過程中,一旦發現了只具有弱引用的對象,不管當前內存空間足夠與否,都會回收它的內存。不過,由于垃圾回收器是一個優先級很低的線程,因此不一定會很快發現那些只具有弱引用的對象。

 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值。

四. 虛引用(PhantomReference)

虛引用顧名思義,就是形同虛設。與其他幾種引用都不同,虛引用并不會決定對象的生命周期。如果一個對象僅持有虛引用,那么它就和沒有任何引用一樣,在任何時候都可能被垃圾回收器回收。

應用場景

虛引用主要用來跟蹤對象被垃圾回收器回收的活動。 虛引用與軟引用和弱引用的一個區別在于:

虛引用必須和引用隊列(ReferenceQueue)聯合使用。當垃圾回收器準備回收一個對象時,如果發現它還有虛引用,就會在回收對象的內存之前,把這個虛引用加入到與之關聯的引用隊列中。

    String str = new String("abc");
    ReferenceQueue queue = new ReferenceQueue();
    // 創建虛引用,要求必須與一個引用隊列關聯
    PhantomReference pr = new PhantomReference(str, queue);

程序可以通過判斷引用隊列中是否已經加入了虛引用,來了解被引用的對象是否將要進行垃圾回收。如果程序發現某個虛引用已經被加入到引用隊列,那么就可以在所引用的對象的內存被回收之前采取必要的行動。

“Java中的引用知識點總結”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

文化| 本溪| 玉树县| 阿城市| 疏附县| 来宾市| 利辛县| 祁连县| 天等县| 金昌市| 措勤县| 沙河市| 新田县| 武山县| 青浦区| 高安市| 资兴市| 怀化市| 东源县| 普定县| 双柏县| 潮州市| 西华县| 湖北省| 南康市| 海门市| 永康市| 河间市| 阳高县| 隆子县| 九江市| 临江市| 思南县| 文成县| 成安县| 自贡市| 安吉县| 武鸣县| 偏关县| 浏阳市| 海原县|