两个引用指向同一个对象的内存图

本文介绍了两个对象引用指向同一内存地址的本质,即对象共享堆内存。接着讨论了垃圾回收的概念,包括引用计数和可达性算法两种策略。引用计数通过跟踪对象的引用次数来判断是否可回收,而可达性算法则基于对象间的引用关系来决定对象的存活状态。此外,提到了不同类型的引用,如强引用、软引用、弱引用和虚引用,这些都影响着对象的生命周期和垃圾回收。

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

1 两个引用指向同一个对象的内存图的本质是什么

俩个对象引用共享同一块堆内存的空间(地址是相同的)

2 什么是垃圾回收

当这个对象的地址,不能再被访问到,变成垃圾,等待空闲时间会被垃圾回收器回收(gc(),感兴趣可以去论坛看一下)

"引用计数算法"

引用计数是垃圾收集器中的早期策略。在这种方法中,堆中每个对象实例都有一个引用计数。当一个对象被创建时,且将该对象实例分配给一个变量,该变量计数设置为1。当任何其它变量被赋值为这个对象的引用时,计数加1(a = b,则b引用的对象实例的计数器+1),但当一个对象实例的某个引用超过了生命周期或者被设置为一个新值时,对象实例的引用计数器减1。任何引用计数器为0的对象实例可以被当作垃圾收集。当一个对象实例被垃圾收集时,它引用的任何对象实例的引用计数器减1。

"可达性算法"

该方法的基本思想是通过一系列的“GC Roots”对象作为起点进行搜索,如果在“GC Roots”和一个对象之间没有可达路径,则称该对象是不可达的,不过要注意的是被判定为不可达的对象不一定就会成为可回收对象。

一个对象的引用 强引用 软引用 弱引用 虚引用

详细看博客:https://www.cnblogs.com/jxldjsn/p/11127897.html仅供参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值