Java中引用的实现遇到的问题总结

本文通过一个实例演示了软引用在Java中的工作原理。在不同内存条件下,软引用的行为差异显著。尤其是在面临内存压力时,软引用会被垃圾回收机制回收以避免出现OutOfMemoryError。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

实现软引用

实现代码

       SoftReference<byte[]> softReference = new SoftReference<>(new byte[1024 * 1024 * 10]);
        System.out.println(softReference.get());
        System.gc();
        try {
            Thread.sleep(500);
        } catch (Exception e) {
            e.printStackTrace();
        }
        System.out.println(softReference.get());
        byte[] bytes = new byte[1024 * 1024 * 15];
        System.out.println(softReference.get());

其中将虚拟机最大内存设置为20M
在这里插入图片描述
其中,软引用分配10M内存大小,然后经历一次GC,因为此时还有内存空间,不会引起OOM,所以软引用是不会被回收的。
后边再创建一个内存大小为15M的强引用,此时会产生OOM,因此在产生OOM之前会将软引用的内存回收掉。给强引用分配内存,程序结束。
执行结果:

[B@5caf905d
[B@5caf905d
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
	at com.blithe.controller.SoftReferenceDemo.main(SoftReferenceDemo.java:16)

What!!! 怎么OOM了!!!不对劲,捋捋思路
大对象直接进入老年区,老年代:新生代默认比例为2:1
在这里插入图片描述
就是说老年区内存也只有不到14M,当分配对象大于14M的时候自然就OOM了
设置参数-XX:NewRatio=9,使老年区:新生区 = 9:1,即老年区占用内存18M。
在这里插入图片描述
再次执行

[B@5caf905d
[B@5caf905d
null

完美,软引用内存被回收。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值