垃圾回收的知识点

为什么要有垃圾回收?

在编程中,动态分配内存是一种常见的操作。当程序动态分配内存后,如果不再需要这部分内存,应该将其释放以便其他程序使用。然而,在手动管理内存的情况下,程序员需要显式地跟踪内存的分配和释放,容易出现内存泄漏(分配的内存未被释放)或者野指针(指向已释放内存的指针)等问题。为了解决这些内存管理问题,引入了垃圾回收机制。

垃圾回收主要回收哪个内存区域?

垃圾回收主要回收堆内存中不再使用的对象。堆内存是用来存储动态分配的内存对象的区域,而栈内存则用来存储局部变量和函数调用信息。

标记的过程:

标记阶段是垃圾回收的一部分,用于标记所有活动对象。这个过程通过从根对象开始,递归遍历对象图,标记所有可以访问到的活动对象,而无法访问到的对象则被标记为垃圾等待回收。

回收的过程:

回收阶段是垃圾回收的另一个关键步骤,目的是将已经标记为垃圾的对象进行回收,并释放它们所占用的内存空间。回收过程可以采用不同的算法,例如标记-清除、复制、标记-整理等。

垃圾回收器有哪些典型实现?

垃圾回收器有多种典型实现,常见的包括:

  1. 标记-清除(Mark and Sweep):标记出所有活动对象,然后清除未标记的垃圾对象。

  2. 复制(Copying):将存活的对象复制到另一个空间,清除未复制的对象。

  3. 标记-整理(Mark and Compact):标记出所有活动对象,然后将它们整理到一端,清除另一端的垃圾对象。

  4. 分代(Generational):根据对象的存活时间将内存分为不同代,针对不同代采用不同的回收策略。

这些是常见的垃圾回收器实现方式,不同的实现方式在性能和内存利用率上有各自的优劣。

相关推荐
爱编程的小吴10 分钟前
【力扣练习题】167. 两数之和 II - 输入有序数组
算法·leetcode·职场和发展
sunfove15 分钟前
打破物理与算法的边界:超分辨率成像原理深度解析
算法·成像·超分辨城乡
wearegogog1237 小时前
基于 MATLAB 的卡尔曼滤波器实现,用于消除噪声并估算信号
前端·算法·matlab
韩师学子--小倪7 小时前
fastjson与gson的toString差异
java·json
一只小小汤圆7 小时前
几何算法库
算法
Drawing stars7 小时前
JAVA后端 前端 大模型应用 学习路线
java·前端·学习
Evand J8 小时前
【2026课题推荐】DOA定位——MUSIC算法进行多传感器协同目标定位。附MATLAB例程运行结果
开发语言·算法·matlab
nbsaas-boot8 小时前
SQL Server 存储过程开发规范(公司内部模板)
java·服务器·数据库
行百里er8 小时前
用 ThreadLocal + Deque 打造一个“线程专属的调用栈” —— Spring Insight 的上下文管理术
java·后端·架构
leo__5208 小时前
基于MATLAB的交互式多模型跟踪算法(IMM)实现
人工智能·算法·matlab