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

Java基礎(chǔ)之引用相關(guān)知識總結(jié)

 更新時(shí)間:2021年05月21日 14:14:33   作者:香菜聊游戲  
今天聊聊Java的引用,大多數(shù)時(shí)候我們說引用都是強(qiáng)引用,只有在對象不使用的情況下才會釋放內(nèi)存,其實(shí)Java 內(nèi)存有四種不同的引用.一起看看吧,,需要的朋友可以參考下

一、引用的定義

在JDK 1.2以前,Java中的引用定義很傳統(tǒng):如果reference類型的數(shù)據(jù)存儲的數(shù)值代表的是另外一塊內(nèi)存的起始地址,就稱這塊內(nèi)存代表著一個(gè)引用。

二、問題

當(dāng)描述這樣的一類對象:當(dāng)內(nèi)存空間還足夠時(shí),則能保留在內(nèi)存之中,如果內(nèi)存空間在進(jìn)行垃圾收集后還是非常緊張,則可以拋棄這些對象。此時(shí)的引用就顯得過于狹隘。因此在JDK 1.2之后,Java堆引用的概念進(jìn)行了擴(kuò)充。

三、引用的分類

回收時(shí)機(jī)
強(qiáng)引用 Strong Reference 類似Object obj = new Object() 只要強(qiáng)引用還存在,垃圾收集器永遠(yuǎn)不會回收掉被引用的對象
軟引用 Soft Reference 描述一些還有用但并非必須的對象 在系統(tǒng)將要發(fā)生內(nèi)存溢出的異常之前,將會把這些對象列進(jìn)回收范圍之中進(jìn)行第二次回收。如果這次回收還沒有足夠的內(nèi)存,才會拋出內(nèi)存溢出異常
弱引用 Weak Reference 用來描述非必須對象,強(qiáng)度比軟引用更弱。被弱引用關(guān)聯(lián)的對象只能生存到下一次垃圾收集發(fā)生之前 當(dāng)垃圾收集器工作時(shí),無論當(dāng)前內(nèi)存是否足夠,都會回收掉紙杯弱引用關(guān)聯(lián)的對象
虛引用 Phantom Reference 又稱為幽靈引用或幻影引用,最弱的一種引用關(guān)系。一個(gè)對象是否有虛引用的存在,完全不會對其生存時(shí)間構(gòu)成影響,也無法通過虛引用來取得一個(gè)對象實(shí)例。 為一個(gè)對象設(shè)置虛引用關(guān)聯(lián)的衛(wèi)衣目的就是能在這個(gè)對象被收集器回收時(shí)收到一個(gè)系統(tǒng)通知

四、應(yīng)用場景

1.強(qiáng)引用

最常用的,應(yīng)用場景最多,everywhere

2.軟引用

只有將要發(fā)生OOM的時(shí)候,才會主動回收,應(yīng)用在一些內(nèi)存限制比較大的應(yīng)用內(nèi),避免發(fā)生OOM。

3.弱引用

不管是young gc 還是 full gc 都會回收弱引用的對象。當(dāng)你想引用一個(gè)對象,但是這個(gè)對象有自己的生命周期,你不想介入這個(gè)對象的生命周期,這時(shí)候你就是用弱引用。

4.虛引用

在回收時(shí)可以檢測到,虛引用主要用來跟蹤對象被垃圾回收器回收的活動。

五、源碼

package org.pdool.ref;
​
import java.lang.ref.Reference;
import java.lang.ref.ReferenceQueue;
import java.lang.ref.WeakReference;
import java.util.LinkedList;
​
public class ReferenceTest {
​
    private static ReferenceQueue<VeryBig> rq = new ReferenceQueue<VeryBig>();
​
    public static void checkQueue() {
        Reference<? extends VeryBig> ref = null;
        while ((ref = rq.poll()) != null) {
            //   只留有引用,沒有對象
            System.out.println("In queue: "    + ((VeryBigWeakReference) (ref)).id);
        }
    }
​
    public static void main(String args[]) {
        int size = 3;
        LinkedList<WeakReference<VeryBig>> weakList = new LinkedList<WeakReference<VeryBig>>();
        for (int i = 0; i < size; i++) {
            weakList.add(new VeryBigWeakReference(new VeryBig("Weak " + i), rq));
            System.out.println("Just created weak: " + weakList.getLast());
        }
​
        System.gc();
        try {
            // 暫停6s,讓上面的垃圾回收線程運(yùn)行完成
            Thread.currentThread().sleep(6000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        checkQueue();
    }
}
​
class VeryBig {
    public String id;
    // 占用空間,讓線程進(jìn)行回收
    byte[] b = new byte[2 * 1024];
​
    public VeryBig(String id) {
        this.id = id;
    }
​
    protected void finalize() {
        System.out.println("Finalizing VeryBig " + id);
    }
}
​
class VeryBigWeakReference extends WeakReference<VeryBig> {
    public String id;
​
    public VeryBigWeakReference(VeryBig big, ReferenceQueue<VeryBig> rq) {
        super(big, rq);
        this.id = big.id;
    }
​
    protected void finalize() {
        System.out.println("Finalizing VeryBigWeakReference " + id);
    }
}

六、總結(jié)

雖然Java提供了這么多引用,但是在平常的業(yè)務(wù)開發(fā)中基本上只要強(qiáng)引用就可以了,整體來說上面除了強(qiáng)引用其他三個(gè)引用都是和內(nèi)存相關(guān)的,只要在開發(fā)中不要內(nèi)存泄漏,基本上內(nèi)存不會出現(xiàn)問題

到此這篇關(guān)于Java基礎(chǔ)之引用相關(guān)知識總結(jié)的文章就介紹到這了,更多相關(guān)Java引用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot內(nèi)存數(shù)據(jù)導(dǎo)出成Excel的實(shí)現(xiàn)方法

    SpringBoot內(nèi)存數(shù)據(jù)導(dǎo)出成Excel的實(shí)現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于SpringBoot內(nèi)存數(shù)據(jù)導(dǎo)出成Excel的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • JVM Tomcat性能實(shí)戰(zhàn)(推薦)

    JVM Tomcat性能實(shí)戰(zhàn)(推薦)

    下面小編就為大家?guī)硪黄狫VM Tomcat性能實(shí)戰(zhàn)(推薦)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-05-05
  • 排序算法圖解之Java選擇排序

    排序算法圖解之Java選擇排序

    選擇排序的工作原理是:第一次從待排序的數(shù)據(jù)元素中選出最小(或最大)的一個(gè)元素,存放在序列的起始位置,然后再從剩余的未排序元素中尋找到最?。ù螅┰兀缓蠓诺揭雅判虻男蛄械哪┪?。本文通過圖片和示例介紹了選擇排序,需要的可以參考一下
    2022-11-11
  • Spring @async方法如何添加注解實(shí)現(xiàn)異步調(diào)用

    Spring @async方法如何添加注解實(shí)現(xiàn)異步調(diào)用

    這篇文章主要介紹了Spring @async方法如何添加注解實(shí)現(xiàn)異步調(diào)用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • Java實(shí)現(xiàn)動態(tài)創(chuàng)建類操作示例

    Java實(shí)現(xiàn)動態(tài)創(chuàng)建類操作示例

    這篇文章主要介紹了Java實(shí)現(xiàn)動態(tài)創(chuàng)建類操作,結(jié)合完整示例形式分析了Java動態(tài)創(chuàng)建類的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下
    2020-02-02
  • idea中Tomcat啟動失敗的解決

    idea中Tomcat啟動失敗的解決

    這篇文章主要介紹了idea中Tomcat啟動失敗的解決,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-09-09
  • Java中的位運(yùn)算符全解

    Java中的位運(yùn)算符全解

    這篇文章主要為大家詳細(xì)介紹了Java中的位運(yùn)算符,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • Java實(shí)現(xiàn)KFC點(diǎn)餐系統(tǒng)過程解析

    Java實(shí)現(xiàn)KFC點(diǎn)餐系統(tǒng)過程解析

    這篇文章主要介紹了Java實(shí)現(xiàn)KFC點(diǎn)餐系統(tǒng)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10
  • JAVA如何使用Math類操作數(shù)據(jù)

    JAVA如何使用Math類操作數(shù)據(jù)

    這篇文章主要介紹了JAVA如何使用Math類操作數(shù)據(jù),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • java編程題之順時(shí)針打印矩陣

    java編程題之順時(shí)針打印矩陣

    這篇文章主要為大家詳細(xì)介紹了java編程題之順時(shí)針打印矩陣,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03

最新評論