V8通过分代回收机制自动管理内存,新生代用Scavenge算法快速回收短生命周期对象,老生代采用标记-清除与标记-整理结合策略,并引入增量标记、并发与并行回收优化性能,减少主线程阻塞,提升应用响应速度。

JavaScript 的内存管理是自动执行的,开发者通常不需要手动分配或释放内存。在 V8 引擎中,这种机制主要依赖于垃圾回收(Garbage Collection, GC)来实现。理解 V8 的内存管理与垃圾回收策略,有助于写出更高效、避免内存泄漏的代码。
内存分配机制
V8 在执行 JS 代码时会为对象分配内存,主要分为两个区域:
- 新生代(Young Generation):存放生命周期短的对象。空间较小,回收频繁。
- 老生代(Old Generation):存放存活时间较长或体积较大的对象。空间大,回收频率较低。
这种分代设计基于“**多数对象朝生夕死**”的经验观察,使垃圾回收更高效。
新生代垃圾回收 —— Scavenge 算法
新生代使用 Scavenge 算法,具体采用的是 ** Cheney 算法 **: 将空间分为“From”和“To”两个半区。
- 新对象被分配在 From 空间。
- 当 From 空间满时,启动 GC,遍历存活对象并复制到 To 空间。
- 复制完成后,清空 From 空间,角色互换。
该算法速度快,但只适用于小空间。对于经过多次回收仍存活的对象,会晋升到老生代(称为“晋升”)。
老生代垃圾回收 —— 标记-清除 与 标记-整理
老生代对象多且存活率高,不适合复制算法。V8 使用以下两种策略:
- 标记-清除(Mark-Sweep):遍历所有对象,标记可达对象,清除未标记的垃圾。但会产生内存碎片。
- 标记-整理(Mark-Compact):在标记后,将存活对象向一端移动,整理碎片,提升内存利用率。
V8 通常先用标记-清除,当内存碎片严重时触发标记-整理。
增量标记与并发回收
为了减少 GC 对主线程的阻塞,现代 V8 引入了优化机制:
- 增量标记:将标记过程拆分为多个小步骤,穿插在 JS 执行中,降低单次停顿时间。
- 并发标记:在单独线程中进行标记,不影响主线程执行。
- 并行回收:使用多个线程同时处理回收任务,加快速度。
这些技术显著提升了应用的响应性能,尤其对大型 Web 应用至关重要。
基本上就这些。掌握 V8 的分代回收机制和优化手段,能帮助你更好地规避内存问题,比如避免频繁创建短期对象、及时解除引用等。不复杂但容易忽略。










