新生代回收器采用复制算法,因对象存活率低,如Serial、ParNew、Parallel Scavenge;老生代用标记-清除或标记-整理,因对象存活率高,如Serial Old、Parallel Old、CMS;G1打破分代界限,实现可预测停顿。

新生代和老生代的垃圾回收器设计不同,主要是因为这两块区域里的对象特性不一样。新生代里大多是“朝生夕死”的短命对象,回收频繁;而老生代存放的是长期存活的对象,回收次数少但影响大。针对这些特点,JVM为它们配备了不同的回收器和算法。
新生代回收器:
- Serial:单线程回收器,简单高效,适合客户端或资源受限环境。老生代回收器:
- Serial Old:Serial的老年代版本,也是单线程,采用标记-整理算法。新生代回收器普遍采用复制算法。因为新生代中大多数对象用完就丢,存活率很低。回收时只需把少数存活对象复制到另一块区域,效率很高,还能避免内存碎片。这种GC叫Minor GC,速度快,一般在毫秒级完成,但会暂停应用(STW)。
老生代则不同,对象存活率高,如果用复制算法,每次都要搬动大量对象,代价太大。所以老生代多用标记-清除或标记-整理算法。先标记出所有活对象,再清理垃圾。CMS就是典型的并发标记清除,尽量减少停顿。而Parallel Old这类则偏向于在STW期间高效完成整理。老年代GC(Major GC/Full GC)耗时较长,可能达到秒级,对应用影响更大。
传统回收器需要成对出现,比如Serial+Serial Old、ParNew+CMS、Parallel Scavenge+Parallel Old。这种组合保证了新生代和老生代能协同工作。不过像G1这样的现代回收器,不再严格区分代,而是把堆分成多个Region,按需回收,追求更短且可预测的停顿时间,逐渐成为大内存服务端的主流选择。
基本上就这些,理解它们的关键是抓住“对象生命周期”这个核心差异。
 
                        
                        每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
 
                 
                                
                                 收藏
收藏
                                                                             
                                
                                 收藏
收藏
                                                                             
                                
                                 收藏
收藏
                                                                            Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号