欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中弱引用和軟引用的區(qū)別以及虛引用和強(qiáng)引用介紹

 更新時(shí)間:2014年04月17日 08:51:19   作者:  
很早Java API就添加了弱引用(WeakReference)和軟引用(SoftReference),但并不是所有的程序員都熟悉這兩個(gè)概念

知道弱引用和軟引用的概念與如何使用它們是兩碼事,引用類在垃圾回收工作的過程中有重要作用。我們都知道垃圾回收器會(huì)回收符合回收條件的對(duì)象的內(nèi)存,但并不是所有的程序員都知道回收條件取決于指向該對(duì)象的引用類型。這正是Java中弱引用和軟引用的主要區(qū)別。如果一個(gè)對(duì)象只有弱引用指向它,垃圾回收器會(huì)立即回收該對(duì)象,這是一種急切回收方式。相對(duì)的,如果有軟引用指向這些對(duì)象,則只有在JVM需要內(nèi)存時(shí)才回收這些對(duì)象。弱引用和軟引用的特殊行為使得它們?cè)谀承┣闆r下非常有用。例如:軟引用可以很好的用來實(shí)現(xiàn)緩存,當(dāng)JVM需要內(nèi)存時(shí),垃圾回收器就會(huì)回收這些只有被軟引用指向的對(duì)象。而弱引用非常適合存儲(chǔ)元數(shù)據(jù),例如:存儲(chǔ)ClassLoader引用。如果沒有類被加載,那么也沒有指向ClassLoader的引用。一旦上一次的強(qiáng)引用被去除,只有弱引用的ClassLoader就會(huì)被回收。這篇文章中我們將講述不同類型的Java引用,例如:強(qiáng)引用(Strong Reference)和虛引用(PhantomReference)。

Java中弱引用VS軟引用

Java中有如下四種類型的引用:

1.強(qiáng)引用(Strong Reference)
2.弱引用(WeakReference)
3.軟引用(SoftReference)
4.虛引用(PhantomReference)

強(qiáng)引用是我們?cè)诰幊踢^程中使用的最簡(jiǎn)單的引用,如代碼String s=”abc”中變量s就是字符串對(duì)象”abc”的一個(gè)強(qiáng)引用。任何被強(qiáng)引用指向的對(duì)象都不能被垃圾回收器回收,這些對(duì)象都是在程序中需要的。弱引用使用java.lang.ref.WeakReference class 類來表示,你可以使用如下代碼創(chuàng)建弱引用:

復(fù)制代碼 代碼如下:

Counter counter = new Counter(); // strong reference - line 1
WeakReference<Counter> weakCounter = new WeakReference<Counter>(counter); //weak reference
counter = null; // now Counter object is eligible for garbage collection

現(xiàn)在只要你給強(qiáng)引用對(duì)象counter賦空值null,該對(duì)象就可以被垃圾回收器回收。因?yàn)樵搶?duì)象此時(shí)不再含有其他強(qiáng)引用,即使指向該對(duì)象的弱引用weakCounter也無法阻止垃圾回收器對(duì)該對(duì)象的回收。相反的,如果該對(duì)象含有軟引用,Counter對(duì)象不會(huì)立即被回收,除非JVM需要內(nèi)存。Java中的軟引用使用java.lang.ref.SoftReference類來表示,你可以使用如下代碼創(chuàng)建軟引用:

復(fù)制代碼 代碼如下:

Counter prime = new Counter(); // prime holds a strong reference – line 2
SoftReference soft = new SoftReference(prime) ; //soft reference variable has SoftReference to Counter Object created at line 2

prime = null; // now Counter object is eligible for garbage collection but only be collected when JVM absolutely needs memory

強(qiáng)引用置空之后,代碼的第二行為對(duì)象Counter創(chuàng)建了一個(gè)軟引用,該引用同樣不能阻止垃圾回收器回收對(duì)象,但是可以延遲回收,與弱引用中急切回收對(duì)象不同。鑒于軟引用和弱引用的這一區(qū)別,軟引用更適用于緩存機(jī)制,而弱引用更適用于存貯元數(shù)據(jù)。另一個(gè)使用弱引用的例子是WeakHashMap,它是除HashMap和TreeMap之外,Map接口的另一種實(shí)現(xiàn)。WeakHashMap有一個(gè)特點(diǎn):map中的鍵值(keys)都被封裝成弱引用,也就是說一旦強(qiáng)引用被刪除,WeakHashMap內(nèi)部的弱引用就無法阻止該對(duì)象被垃圾回收器回收。

虛引用是java.lang.ref package包中第三種可用的引用,使用java.lang.ref.PhantomReference類來表示。擁有虛引用的對(duì)象可以在任何時(shí)候被垃圾回收器回收。和弱引用和軟引用相似,你可以通過如下代碼創(chuàng)建虛引用:

復(fù)制代碼 代碼如下:

DigitalCounter digit = new DigitalCounter(); // digit reference variable has strong reference – line 3
PhantomReference phantom = new PhantomReference(digit); // phantom reference to object created at line 3

digit = null;

一旦移除強(qiáng)引用,第三行的DigitalCounter對(duì)象可以在任何時(shí)候被垃圾回收器回收。因?yàn)橹挥幸粋€(gè)虛引用指向該對(duì)象,而虛引用無法阻止垃圾回收器回收對(duì)象。

除了了解弱引用、軟引用、虛引用和WeakHashMap,還需要了解ReferenceQueue。在創(chuàng)建任何弱引用、軟引用和虛引用的過程中你可以通過如下代碼提供引用隊(duì)列ReferenceQueue:

復(fù)制代碼 代碼如下:

ReferenceQueue refQueue = new ReferenceQueue(); //reference will be stored in this queue for cleanup
DigitalCounter digit = new DigitalCounter();
PhantomReference<DigitalCounter> phantom = new PhantomReference<DigitalCounter>(digit, refQueue);

引用實(shí)例被添加在引用隊(duì)列中,你可以再任何時(shí)候通過查詢引用隊(duì)列回收對(duì)象。一個(gè)對(duì)象的生命周期可以通過下圖進(jìn)行描述:

 

這就是Java中弱引用和軟引用的區(qū)別。我們還學(xué)到了一些基本的引用類:弱引用、軟引用、虛引用以及WeakHashMap和WeakHashMap。總之,合理的使用引用可以幫助垃圾回收器更好的管理Java內(nèi)存。

相關(guān)文章

  • 淺談SpringBoot項(xiàng)目打成war和jar的區(qū)別

    淺談SpringBoot項(xiàng)目打成war和jar的區(qū)別

    這篇文章主要介紹了淺談SpringBoot項(xiàng)目打成war和jar的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Spring計(jì)時(shí)器stopwatch使用詳解

    Spring計(jì)時(shí)器stopwatch使用詳解

    這篇文章主要介紹了Spring計(jì)時(shí)器stopwatch使用詳解,本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Java kafka如何實(shí)現(xiàn)自定義分區(qū)類和攔截器

    Java kafka如何實(shí)現(xiàn)自定義分區(qū)類和攔截器

    這篇文章主要介紹了Java kafka如何實(shí)現(xiàn)自定義分區(qū)類和攔截器,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • 對(duì)ThreadLocal內(nèi)存泄漏及弱引用的理解

    對(duì)ThreadLocal內(nèi)存泄漏及弱引用的理解

    這篇文章主要介紹了對(duì)ThreadLocal內(nèi)存泄漏及弱引用的理解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • 淺談Arrays.asList()方法的使用

    淺談Arrays.asList()方法的使用

    本文主要介紹了Arrays.asList()方法的使用。具有很好的參考價(jià)值,下面跟著小編一起來看下吧
    2017-02-02
  • Java線程池的幾種實(shí)現(xiàn)方法及常見問題解答

    Java線程池的幾種實(shí)現(xiàn)方法及常見問題解答

    下面小編就為大家?guī)硪黄狫ava線程池的幾種實(shí)現(xiàn)方法及常見問題解答。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-05-05
  • 深入理解Java設(shè)計(jì)模式之策略模式

    深入理解Java設(shè)計(jì)模式之策略模式

    這篇文章主要介紹了JAVA設(shè)計(jì)模式之策略模式的的相關(guān)資料,文中示例代碼非常詳細(xì),供大家參考和學(xué)習(xí),感興趣的朋友可以了解下
    2021-11-11
  • Java持久化XML文件配置解析

    Java持久化XML文件配置解析

    這篇文章主要為大家介紹了Java持久化XML文件配置解析,當(dāng)你在使用?Java?編程語言?來編寫軟件時(shí),實(shí)現(xiàn)持久化配置的方式。有需要的朋友可以借鑒參考下,希望能夠有所幫助<BR>
    2022-03-03
  • 一次排查@CacheEvict注解失效的經(jīng)歷及解決

    一次排查@CacheEvict注解失效的經(jīng)歷及解決

    這篇文章主要介紹了一次排查@CacheEvict注解失效的經(jīng)歷及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • Java數(shù)據(jù)結(jié)構(gòu)之二叉排序樹的實(shí)現(xiàn)

    Java數(shù)據(jù)結(jié)構(gòu)之二叉排序樹的實(shí)現(xiàn)

    二叉排序樹(Binary Sort Tree),又稱二叉查找樹(Binary Search Tree),亦稱二叉搜索樹。本文詳細(xì)介紹了二叉排序樹的原理,并且提供了Java代碼的完全實(shí)現(xiàn)。需要的可以參考一下
    2022-01-01

最新評(píng)論