JavaScript通过垃圾回收机制自动管理内存,核心基于可达性判断对象是否存活。引擎从根对象出发,标记并保留可达对象,清除不可达对象。主流采用标记-清除算法,辅以分代回收提升性能,避免循环引用问题。开发者需注意意外全局变量、闭包、事件监听和定时器等导致的内存泄漏,及时解绑或置null可有效预防。

JavaScript的内存管理是自动进行的,开发者通常不需要手动分配或释放内存。其中最关键的部分就是垃圾回收机制(Garbage Collection, GC)。它负责识别哪些内存不再被使用,并自动释放它们,从而避免内存泄漏。
内存生命周期简要回顾
在了解垃圾回收前,先明确变量的内存生命周期:
- 分配内存:声明变量、对象、函数时,系统自动分配内存。
- 使用内存:读写变量、调用函数等操作使用已分配的内存。
- 释放内存:当内存不再需要时,由垃圾回收器自动回收。
JavaScript中,前两步是开发者直接参与的,而最后一步完全由引擎自动处理。
垃圾回收的核心原理:可达性
现代JavaScript引擎采用“可达性”来判断一个值是否还“活着”。基本思想是:从一组根(如全局对象、当前执行函数的局部变量)开始,能通过引用链访问到的对象被视为可达,保留;无法访问到的则被判定为垃圾,可以回收。
立即学习“Java免费学习笔记(深入)”;
例如:
let obj = { name: "Alice" };obj = null; // 原对象失去引用,若无其他引用,将被回收
此时,原对象不再可达,下次垃圾回收时会被清除。
常见的垃圾回收算法
不同JavaScript引擎(如V8、SpiderMonkey)实现细节略有差异,但主流采用以下两种策略:
caozha-order是一个通用的竞价页订单管理系统,基于开源的caozha-admin开发,支持订单管理、订单回收站、产品管理、批量上传订单、批量导出订单(支持导出格式:.xls,.xlsx,.csv)、检测订单重复、竞价页的下单表单调用等功能,内置灵活的查看订单权限设置机制。系统特点:易上手,零门槛,界面清爽极简,极便于二次开发。
1. 引用计数(Reference Counting)
- 每个对象记录被引用的次数。
- 引用增加,计数加1;引用解除,计数减1。
- 计数为0时立即回收。
缺点:无法处理循环引用。例如:
let a = {};let b = {};
a.ref = b;
b.ref = a;
// 即使a和b不再使用,引用计数都不为0,无法回收
2. 标记-清除(Mark-and-Sweep)
- 从根对象出发,标记所有可达对象。
- 未被标记的对象被视为不可达,进行清除。
- 定期运行,解决循环引用问题。
这是目前主流方法,V8引擎使用优化版的标记-清除算法,并结合分代回收策略提升性能。
如何避免内存泄漏
虽然有垃圾回收,但不当编码仍会导致内存泄漏。常见情况包括:
- 意外的全局变量:未声明的变量会挂在全局对象上,长期不释放。
- 闭包引用过大对象:闭包保持对外部变量的引用,若未及时断开,可能阻止回收。
- 事件监听未解绑:DOM元素被移除后,若事件监听仍存在,可能导致整个DOM树无法回收。
- 定时器引用对象:setInterval中引用对象,即使页面已切换,仍可能驻留内存。
建议:及时将不再使用的对象设为 null(尤其是大型对象),解绑事件,清理定时器。
基本上就这些。JavaScript的垃圾回收让开发更轻松,理解其机制有助于写出更高效、稳定的代码。









