強引用是使用最普遍的引用。如果一個物件具有強引用,那麼垃圾回收器絕對不會回收它。當記憶體空間不足,Java虛擬機寧願拋出OutOfMemoryError錯誤,使程式異常終止,也不會靠隨意回收具有強引用的物件來解決記憶體不足的問題。
如果一個物件只具有軟引用,則記憶體空間足夠,垃圾回收器就不會回收它;如果記憶體空間不足了,就會回收這些對象的記憶體。只要垃圾回收器沒有回收它,該物件就可以被程式使用。軟引用可用於實現記憶體敏感的高速緩存(下文給出範例)。
軟體引用可以和一個引用佇列(ReferenceQueue)共同使用,如果軟引用所引用的物件被垃圾回收器回收,Java虛擬機器就會把這個軟引用加入到與之關聯的引用隊列中。
弱引用與軟引用的差異在於:只具有弱引用的物件擁有更短暫的生命週期。在垃圾回收器線程掃描它所管轄的內存區域的過程中,一旦發現了只具有弱引用的對象,不管當前內存空間足夠與否,都會回收它的內存。不過,由於垃圾回收器是優先順序很低的線程,因此不一定會很快發現那些只具有弱引用的物件。
弱引用可以和一個引用隊列(ReferenceQueue)聯合使用,如果弱引用所引用的物件被垃圾回收,Java虛擬機就會把這個弱引用加入到與之關聯的引用隊列中。
「虛引用」顧名思義,就是形同虛設,與其他幾種引用都不同,虛引用並不會決定物件的生命週期。如果一個物件只持有虛引用,那麼它就和沒有任何引用一樣,在任何時候都可能被垃圾回收器回收。
虛引用主要用來追蹤物件被垃圾回收器回收的活動。虛引用與軟引用和弱引用的一個區別在於:虛引用必須和引用隊列 (ReferenceQueue)聯合使用。當垃圾回收器準備回收一個物件時,如果發現它還有虛引用,就會在回收物件的記憶體之前,把這個虛引用加入到與之 關聯的引用佇列中。
ReferenceQueue queue = new ReferenceQueue (); queue =
newPhantomReference pr
PhantomReference
五、ReferenceQueue
就是一個引用隊列,如果保存的是Reference物件本身,如果:Reference引用指向的物件被GC回收,其實Reference已經無效了
這種Reference將被放入引用隊列,可以在這裡將其清除,避免佔有空間
六、WeakHashMap
弱引用map:就是Key鍵是一個弱引用的鍵,如果Key鍵被回收,則在get該map中值後,會自動remove掉value
如果Key鍵始終被強引用,則是無法被回收的;
### 注意Value是被強引用的,所以不要讓Value間接的引用了Key鍵,這將導致key時鐘被強引用###### 這個:適合於受Key的生命週期控制的快取##### ### ### ###以上是Java物件的強、軟弱、弱、虛引用+ReferenceQueue的詳細內容。更多資訊請關注PHP中文網其他相關文章!