V8引擎采用分代回收策略,新生代用Scavenge算法快速复制存活对象,老生代用标记-清除与标记-整理解决内存碎片;通过增量、并发和并行技术降低GC停顿,提升性能。

V8引擎是Google开发的高性能JavaScript引擎,广泛应用于Chrome浏览器和Node.js中。它不仅负责解析和执行JavaScript代码,还内置了高效的垃圾回收机制,用来自动管理内存,释放不再使用的对象所占用的空间,防止内存泄漏。
内存分配与分代管理
V8将堆内存分为几个区域,主要采用分代回收策略,基于“大多数对象生命周期很短”的观察:
- 新生代(Young Generation):存放生命周期较短的新创建对象。空间较小,回收频繁。
- 老生代(Old Generation):存放存活时间较长或从新生代晋升上来的对象。空间大,回收频率较低。
这种划分让V8可以针对不同代使用不同的回收算法,提升效率。
新生代的Scavenge算法
新生代使用一种叫Scavenge的算法,核心是Copying算法,将新生代空间分为两部分:
立即学习“Java免费学习笔记(深入)”;
- From空间:当前使用的区域。
- To空间:空闲区域,用于复制存活对象。
当触发回收时:
- V8遍历From空间中的活动对象,将仍被引用的对象复制到To空间。
- 未被复制的对象视为垃圾,直接丢弃。
- 完成复制后,交换From和To的角色,原To变成新的From,等待下一次回收。
该过程速度快,但只适用于小空间。对象在新生代经历多次回收后仍存活,会被晋升到老生代。
老生代的标记-清除与标记-整理
老生代对象多、体积大,不适合复制算法。V8采用更复杂的策略:
- 标记阶段(Mark):从根对象(如全局对象、调用栈)开始,递归标记所有可达对象。
- 清除阶段(Sweep):未被标记的对象即为垃圾,其内存被回收。
但清除后会产生内存碎片。为解决这个问题,V8在必要时执行标记-整理(Mark-Compact):
- 将存活对象向一端移动,压缩空隙。
- 整理后释放连续内存,提高利用率。
增量标记与并发回收
早期V8在执行垃圾回收时会暂停JavaScript执行(Stop-The-World),影响性能。现代V8已优化:
- 增量标记:将标记过程拆分成多个小步骤,穿插在JS执行之间,减少单次停顿时间。
- 并发标记:在单独线程中进行标记,主线程可继续执行JS代码。
- 并行回收:利用多核CPU,并行处理清理或整理任务。
这些技术显著降低了GC对应用响应速度的影响,尤其在大型应用中表现明显。
基本上就这些。V8的垃圾回收机制结合分代、算法优化和并发技术,在保证内存安全的同时,最大限度地提升了运行效率。开发者虽无需手动管理内存,但仍需注意避免意外的内存引用,比如未清理的定时器或闭包引用,以防内存泄漏。











