What-什麼是弱引用?
Java中的弱引用具體指的是java.lang.ref.WeakReference
弱引用物件的存在不會阻止它所指向的物件被垃圾回收器回收。弱引用最常見的用途是實作規範映射(canonicalizing mappings,例如雜湊表)。
假設垃圾收集器在某個時間點決定一個物件是弱可達的(weakly reachable)(也就是說目前指向它的全都是弱引用),這時垃圾收集器會清除所有指向該物件的弱引用,然後把這個弱可達物件標記為可終結(finalizable)的,這樣它隨後就會被回收。同時或稍後,垃圾收集器會把那些剛清除的弱引用放入創建弱引用物件時所指定的參考佇列(Reference Queue)中。
實際上,Java中存在四種引用,它們由強到弱依序是:強引用、軟引用、弱引用、虛引用。下面我們簡單介紹下除弱引用外的其他三種引用:
強引用(Strong Reference):通常我們透過new來建立一個新物件時傳回的參考就是一個強引用,若一個物件透過一系列強引用可到達,它就是強可達的(strongly reachable),那麼它就不被回收
軟引用(Soft Reference):軟引用和弱引用的區別在於,若一個物件是弱引用可達,無論當前記憶體是否充足它都會被回收,而軟引用可達的物件在記憶體不充足時才會被回收,因此軟引用要比弱引用「強」一些
虛引用(Phantom Reference):虛引用是Java中最弱的引用,那麼它弱到什麼程度呢?它是如此脆弱以至於我們透過虛引用甚至無法獲取到被引用的對象,虛引用存在的唯一作用就是當它指向的對像被回收後,虛引用本身會被加入到引用隊列中,用作記錄它指向的物件已被回收。
Why-為什麼要使用弱引用?
考慮下面的場景:現在有一個Product類別代表一種產品,這個類別被設計為不可擴展的,而此時我們想要為每個產品增加一個編號。一個解決方案是使用HashMap
所以這種情況下,我們想要真正的回收一個Product對象,僅僅把它的強引用賦值為null是不夠的,還要把相應的條目從HashMap中移除。顯然「從HashMap中移除不再需要的條目」這個工作我們不想自己完成,我們希望告訴垃圾收集器:在只有HashMap中的key在引用著Product物件的情況下,就可以回收對應Product物件了。顯然,根據前面弱引用的定義,使用弱引用能幫助我們達成這個目的。我們只需要用一個指向Product物件的弱引用物件來作為HashMap中的key就可以了。
How——如何使用弱引用?
拿上面介紹的場景舉例,我們使用一個指向Product物件的弱引用物件來作為HashMap的key,只需這樣定義這個弱引用物件:
weakProduct#weakProductA);##weakProduct#weakProduct就指向了Product物件productA。那我們要怎麼透過weakProduct來取得它所指向的Product物件productA呢?很簡單,只需要下面這句程式碼:Product productA = new Product(...);
WeakReferenceweakProductA = new WeakReference<>(productA);
Product product = weakProductA.get();
引用隊列
//创建一个指向给定对象的弱引用 WeakReference(T referent) //创建一个指向给定对象并且登记到给定引用队列的弱引用 WeakReference(T referent, ReferenceQueue<? super T> q)我們可以看到第二個建構方法中提供了一個ReferenceQueue類型的參數,透過提供這個參數,我們就把創建的弱引用物件註冊到了一個引用隊列上,這樣當它被垃圾回收器清除時,就會把它送入這個引用隊列中,我們便可以對這些被清除的弱引用對象進行統一管理。 ###
以上是Java弱引用的學習與了解的詳細內容。更多資訊請關注PHP中文網其他相關文章!