本文目錄一覽:
- 1、java中什麼是強引用,弱引用和軟引用
- 2、java中引用拷貝是不是強引用?如果是那麼:
- 3、Java引用分為強引用、軟引用、弱引用、虛引用,怎麼判斷出一個對象是哪個引用?
- 4、Java中的強引用,軟引用,弱引用,虛引用有什麼用
- 5、java四種引用,強軟弱虛 有大神在嗎
- 6、Java中的幾種引用方式
java中什麼是強引用,弱引用和軟引用
我自己也複習下概念。
強引用:就是普通引用。比如 A o1=new A(); A o2=o1;
強引用只有當所有對這個對象的所有引用(o1,o2)失效後,new A()的內存才會被回收。
殘影引用、弱引用、軟引用都用來引用隨時可能被回收的對象。類似o1,o2即使未失效也會回收。
區別是被回收器回收的激烈程度,由強到弱。
殘影引用是對象已經finalize或者執行完析構函數,只等內存馬上回收了,最容易被回收。非常接近回收時機,就像殘影會隨物體消失而消失,故名。
弱引用的對象是在正常情況下,回收器遇到就回收,是被積極回收的對象。
軟引用是僅在內存不夠時才回收,屬於消極回收。
java中引用拷貝是不是強引用?如果是那麼:
什麼是強引用
強引用就是我們平時使用的對象方式,也是使用最多的一種方式,請記住不管內存
緊張也罷,不足也罷,gc永不回收強引用的對象, 即使jvm 出現(內存溢出錯
誤)OutOfMemoryError,使程序停止,也不會回收對象來提高內存
代碼
public class StrongReferenceDemo {
public static void main(String[] args) {
Integer data = new Integer(4);
String str = “123”;
Student student = new Student();
//以上三個對象都是強引用對象,指我們平時使用的對象方式
}
}
class Student {
}
更多教程:黑馬程序員
Java引用分為強引用、軟引用、弱引用、虛引用,怎麼判斷出一個對象是哪個引用?
根據new的方式。強引用就是 new 你定義的類名。
其餘的引用,都需要包裝類來創建。例如:new 軟引用(你定義的類)
Java中的強引用,軟引用,弱引用,虛引用有什麼用
這兩天在看 Reference 相關的東西,雖然接觸到的場景不多,但感覺還是比較有用的。
在非常關心內存的情況下,有可能能派上用場。
在涉及到某一個對象被 GC,需要得到通知,然後再做某些相關處理的時候,有可能派得上用場。
對於第一點,目前接觸到的就是 WeakHahsMap。像我們平常寫緩存的時候,最簡單的就是在一個類中
public static MapString,String user_map = new HashMapString, String();
然後再在全局使用它。這裡就可以參考下 Tomcat 實現的這個 LRU 緩存:tomcat/ConcurrentCache.java at trunk · apache/tomcat · GitHub,它就用到了 WeakHashMap,WeakHashMap也用到了 WeakReference,可以參考下。
WeakHahsMap 的實現原理簡單來說就是裡面的 Entry 使用繼承了 WeakReference,那麼當 Entry 的 key 不再被使用的時候,也就是被 GC 的時候,那麼該 Entry 就會進入到 ReferenceQueue 中, WeakHashMap 在你調用相關方法的時候,那麼就會把這個 Entry 從 ReferenceQueue 中刪除,並且做相關處理(也就是把這個 key 刪除)。這時候你就會發現,你的一個鍵值對沒有了。
對於第二點,目前接觸到的就是一個 FileCleaningTracker,它的作用是,把一個文件和一個對象關聯起來,當這個對象被 GC 的時候,文件也幫我們刪除掉。
FileCleaningTracker 的實現簡單來說就是用了一個虛引用。它裡面有一個 Tracker 的內部類,他繼承自 PhantomReference,你可以理解成 WeakHashMap中的 Entry(其實也很像了)。這個 Tracker 就和我們的關聯對象 marker 關聯起來(你可以理解成 WeakHashMap 中的 Entry 的 key),那麼當 marker 被回收的時候,Tracker 就會被GC 弄到 ReferenceQueue 中,那麼 FileCleaningTracker 就會把 Tracker 從 ReferenceQueue 移除出來,並且執行相關操作(delete file)。
最後:
自己理解的引用(強,軟,弱虛)是和 GC 比較相關的,能夠在一個 對象被 GC 的時候,應用程序得到通知,然後執行相關操作。像 WeakHashMap 就是這樣,底層發現 key 沒了,上層就把 entry 刪了。
ps:
第6條:消除過期對象的引用(WeakHashMap的緩存應用):願無歲月可回首
第6條:WeakHashMap擴展知識1(原理與Reference相關):願無歲月可回首
第6條:Reference應用-FileCleaningTracker:願無歲月可回首
最後的最後補充。。。
突然想起,之前自己在工作中涉及到這樣一種情況,我需要對用戶投資的錢進行一個每日的加息,有一天客戶忘了把加息的數據給我,然後給了我一份 csv 文件,讓我加上。我當時的做法是,讓運維把文件放在固定的地方,程序讀取,執行邏輯,然後運維再手動刪除。 這個時候,其實也可以通過這種 FileCleaningTracker,當讀取完之後,自動的刪除這個文件,就不用運維來做了。(這可能是一種應用場景)
java四種引用,強軟弱虛 有大神在嗎
Java中四種引用的特點:
強引用(StrongReference)
當我們使用 new 這個關鍵字創建對象時創建出來的對象就是強引用(new出來對象為強引用) 如Object obj = new Object() 這個obj就是一個強引用了,如果一個對象具有強引用。垃圾回收器就不會回收有強引用的對象。如當jvm內存不足時,具備強引用的對象,虛擬機寧可會拋出OutOfMemoryError(內存空間不足),使程序終止,也不會靠垃圾回收器去回收該對象來解決內存。
2.軟引用(SoftReference)
如果一個對象只具有軟引用,那就類似於可有可物的生活用品。如果內存空間足夠,垃圾回收器就不會回收它,如果內存空間不足了,就會回收這些對象的內存。只要垃圾回收器沒有回收它,該對象就可以被程序使用。
軟引用的作用:軟引用可用來實現內存敏感的高速緩存。
軟引用可以和一個引用隊列(ReferenceQueue)聯合使用,如果軟引用所引用的對象被垃圾回收,Java虛擬機就會把這個軟引用加入到與之關聯的引用隊列中。
3.弱引用(WeakReference)
如果一個對象只具有弱引用,那就類似於可有可物的生活用品。弱引用與軟引用的區別在於:只具有弱引用的對象擁有更短暫的生命周期。在垃圾回收器線程掃描它所管轄的內存區域的過程中,一旦發現了只具有弱引用的對象,不管當前內存空間足夠與否,都會回收它的內存。不過,由於垃圾回收器是一個優先順序很低的線程, 因此不一定會很快發現那些只具有弱引用的對象。
弱引用可以和一個引用隊列(ReferenceQueue)聯合使用,如果弱引用所引用的對象被垃圾回收,Java虛擬機就會把這個弱引用加入到與之關聯的引用隊列中。
4.虛引用(PhantomReference)
「虛引用」顧名思義,就是形同虛設,和其他幾種引用都不同,虛引用並不會決定對象的生命周期。如果一個對象僅持有 虛引用,那麼它就和沒有任何引用一樣,在任何時候都可能被垃圾回收器回收。
虛引用主要用來跟蹤對象被垃圾回收器回收的活動。虛引用與軟引用和弱引用的一個區別在於:虛引用必須和引用隊列(ReferenceQueue)聯合使用。當垃圾回收器準備回收一個對象時,如果發現它還有虛引用,就會在回收對象的內存之前,把這個虛引用加入到與之 關聯的引用隊列中。
ReferenceQueue queue = new ReferenceQueue ();
//虛引用對象
PhantomReference pr = new PhantomReference (object, queue);
程序可以通過判斷引用隊列中是否已經加入了虛引用,來了解被引用的對象是否將要被垃圾回收。如果程序發現某個虛引用已經被加入到引用隊列,那麼就可以在所引用的對象的內存被回收之前採取必要的行動。
如果你還想深入了解的話給你推薦一個博文地址:
網頁鏈接
Java中的幾種引用方式
Java中有幾種不同的引用方式,它們分別是:強引用、軟引用、弱引用和虛引用。下面,我們首先詳細地了解下這幾種引用方式的意義。強引用在此之前我們介紹的內容中所使用的引用都是強引用,這是使用最普遍的引用。如果一個對象具有強引用,那就類似於必不可少的生活用品,垃圾回收器絕不會回收它。當內存空 間不足,Java虛擬機寧願拋出OutOfMemoryError錯誤,使程序異常終止,也不會靠隨意回收具有強引用的對象來解決內存不足問題。軟引用(SoftReference)SoftReference 類的一個典型用途就是用於內存敏感的高速緩存。SoftReference 的原理是:在保持對對象的引用時保證在 JVM 報告內存不足情況之前將清除所有的軟引用。關鍵之處在於,垃圾收集器在運行時可能會(也可能不會)釋放軟可及對象。對象是否被釋放取決於垃圾收集器的演算法 以及垃圾收集器運行時可用的內存數量。弱引用(WeakReference)WeakReference 類的一個典型用途就是規範化映射(canonicalized mapping)。另外,對於那些生存期相對較長而且重新創建的開銷也不高的對象來說,弱引用也比較有用。關鍵之處在於,垃圾收集器運行時如果碰到了弱可及對象,將釋放 WeakReference 引用的對象。然而,請注意,垃圾收集器可能要運行多次才能找到並釋放弱可及對象。虛引用(PhantomReference)PhantomReference 類只能用於跟蹤對被引用對象即將進行的收集。同樣,它還能用於執行 pre-mortem 清除操作。PhantomReference 必須與 ReferenceQueue 類一起使用。需要 ReferenceQueue 是因為它能夠充當通知機制。當垃圾收集器確定了某個對象是虛可及對象時,PhantomReference 對象就被放在它的 ReferenceQueue 上。將 PhantomReference 對象放在 ReferenceQueue 上也就是一個通知,表明 PhantomReference 對象引用的對象已經結束,可供收集了。這使您能夠剛好在對象佔用的內存被回收之前採取行動。Reference與ReferenceQueue的配合使用。GC、Reference與ReferenceQueue的交互A、 GC無法刪除存在強引用的對象的內存。B、 GC發現一個只有軟引用的對象內存,那麼:① SoftReference對象的referent 域被設置為null,從而使該對象不再引用heap對象。② SoftReference引用過的heap對象被聲明為finalizable。③ 當heap 對象的 finalize() 方法被運行而且該對象佔用的內存被釋放,SoftReference 對象就被添加到它的 ReferenceQueue(如果後者存在的話)。C、 GC發現一個只有弱引用的對象內存,那麼:① WeakReference對象的referent域被設置為null,從而使該對象不再引用heap對象。② WeakReference引用過的heap對象被聲明為finalizable。③ 當heap對象的finalize()方法被運行而且該對象佔用的內存被釋放時,WeakReference對象就被添加到它的ReferenceQueue(如果後者存在的話)。D、 GC發現一個只有虛引用的對象內存,那麼:① PhantomReference引用過的heap對象被聲明為finalizable。② PhantomReference在堆對象被釋放之前就被添加到它的ReferenceQueue。值得注意的地方有以下幾點:1、GC在一般情況下不會發現軟引用的內存對象,只有在內存明顯不足的時候才會發現並釋放軟引用對象的內存。2、GC對弱引用的發現和釋放也不是立即的,有時需要重複幾次GC,才會發現並釋放弱引用的內存對象。3、軟引用和弱引用在添加到ReferenceQueue的時候,其指向真實內存的引用已經被置為空了,相關的內存也已經被釋放掉了。而虛引用在添加到ReferenceQueue的時候,內存還沒有釋放,仍然可以對其進行訪問。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/155337.html