导读:本期聚焦于小伙伴创作的《Reference类体系中的强引用、软引用、弱引用、虚引用有什么区别》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《Reference类体系中的强引用、软引用、弱引用、虚引用有什么区别》有用,将其分享出去将是对创作者最好的鼓励。

Java中的Reference类体系定义了四种不同的引用类型,分别是强引用、软引用、弱引用和虚引用,它们在垃圾回收时的处理规则不同,直接决定了对象的存活时间,是内存优化的重要基础知识点。

Reference类体系中的强引用、软引用、弱引用、虚引用有什么区别

强引用

强引用是日常开发中最常用的引用类型,我们平时通过new关键字创建的对象关联的都是强引用。只要强引用存在,垃圾回收器就不会回收被引用的对象,哪怕内存空间不足时,JVM也会优先抛出OutOfMemoryError,而不会回收强引用指向的对象。

强引用示例

public class StrongReferenceDemo {
    public static void main(String[] args) {
        // 创建强引用,obj指向新创建的Object对象
        Object obj = new Object();
        // 此时obj是强引用,垃圾回收器不会回收该Object对象
        System.gc();
        // 即使手动触发GC,obj指向的对象也不会被回收
        System.out.println(obj != null); // 输出true
        // 断开强引用
        obj = null;
        // 此时对象没有强引用指向,下次GC时会被回收
        System.gc();
    }
}

软引用

软引用通过SoftReference类实现,当内存空间充足时,软引用指向的对象不会被回收;只有当内存空间不足,即将发生OutOfMemoryError时,垃圾回收器才会回收软引用指向的对象。这种特性让软引用非常适合用于实现内存敏感的缓存场景。

软引用示例

import java.lang.ref.SoftReference;

public class SoftReferenceDemo {
    public static void main(String[] args) {
        // 创建软引用,指向一个大小为10MB的字节数组
        SoftReference<byte[]> softRef = new SoftReference<>(new byte[10 * 1024 * 1024]);
        // 内存充足时,软引用对象不会被回收
        System.out.println(softRef.get() != null); // 输出true
        // 尝试分配大内存,触发内存不足
        try {
            byte[] bigArray = new byte[20 * 1024 * 1024];
        } catch (OutOfMemoryError e) {
            // 内存不足时,软引用指向的对象会被回收
            System.out.println(softRef.get() == null); // 输出true
        }
    }
}

弱引用

弱引用通过WeakReference类实现,弱引用的生命周期比软引用更短,只要垃圾回收器扫描到弱引用指向的对象,不管当前内存是否充足,都会回收该对象。弱引用常用来实现一些临时关联的场景,避免内存泄漏。

弱引用示例

import java.lang.ref.WeakReference;

public class WeakReferenceDemo {
    public static void main(String[] args) {
        // 创建弱引用
        WeakReference<Object> weakRef = new WeakReference<>(new Object());
        // 触发一次GC
        System.gc();
        // 弱引用指向的对象会被回收
        System.out.println(weakRef.get() == null); // 输出true
    }
}

WeakHashMap就是基于弱引用实现的,它的key是弱引用,当key没有其他强引用指向时,对应的键值对会在GC时被自动移除,避免内存泄漏。

虚引用

虚引用通过PhantomReference类实现,它是最弱的一种引用类型,虚引用完全不会影响对象的生命周期,也无法通过虚引用获取到对象实例。虚引用的主要作用是在对象被垃圾回收时收到一个系统通知,通常用来跟踪对象被垃圾回收的状态。

虚引用示例

import java.lang.ref.PhantomReference;
import java.lang.ref.ReferenceQueue;

public class PhantomReferenceDemo {
    public static void main(String[] args) {
        Object obj = new Object();
        // 创建引用队列
        ReferenceQueue<Object> queue = new ReferenceQueue<>();
        // 创建虚引用,关联引用队列
        PhantomReference<Object> phantomRef = new PhantomReference<>(obj, queue);
        // 无法通过虚引用获取对象
        System.out.println(phantomRef.get() == null); // 输出true
        // 断开强引用
        obj = null;
        // 触发GC
        System.gc();
        // 虚引用指向的对象被回收后,虚引用会被加入引用队列
        System.out.println(queue.poll() == phantomRef); // 输出true
    }
}

四种引用对比

四种引用的核心差异可以通过以下表格清晰展示:

引用类型实现类回收时机典型应用场景
强引用只要引用存在,永不回收普通对象关联
软引用SoftReference内存不足时回收内存敏感缓存
弱引用WeakReferenceGC时必然回收临时关联、WeakHashMap
虚引用PhantomReferenceGC时回收,触发通知跟踪对象回收状态

使用注意事项

  • 强引用要避免不必要的长生命周期持有,否则容易导致内存泄漏。
  • 使用软引用和弱引用时,要注意判断get()方法返回的结果是否为null,因为对象可能已经被回收。
  • 虚引用必须和引用队列配合使用,否则无法感知对象的回收状态。

Reference类体系强引用软引用弱引用虚引用修改时间:2026-06-26 00:15:54

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。