2009xyz 2023-02-09 19:36 采纳率: 100%
浏览 39
已结题

关于JVM垃圾回收机制

在回答为什么老年代垃圾回收比年轻代垃圾回收慢的时候,答案里面写到“因为新生代标记存活对象很快,因为新生代存活对象很少;而老年代存活对象很多,在并发标记阶段追踪对象时间成本大”。

但是,在标记存活对象的时候,不是要遍历所有的对象吗,来判断它们是否从根源上被GC roots引用吗,这样的话,它们都是O(n)的时间复杂度,应该时间成本差不多。

还有一个问题,这俩个回收机制都是标记存活对象吗,像上面说的,标记对象,无论垃圾还是存活对象都要遍历全部对象,因此标记存活对象和标记垃圾对象有什么意义呢?这两个应该是等价的。

  • 写回答

3条回答 默认 最新

  • 春休夏末 2023-02-09 19:48
    关注

    第一:老年代垃圾回收比年轻代垃圾回收慢,是因为老年代的垃圾回收器要处理的对象比较多,而年轻代的垃圾回收器处理的对象比较少。
    第二:这两个回收机制都是标记存活对象,但是它们的标记方式是不同的。老年代垃圾回收器采用的是标记-清除算法,先标记出所有可能存活的对象,然后清除没有标记的对象;而年轻代垃圾回收器采用的是复制算法,标记出可能存活的对象,然后将存活的对象复制到另一块内存空间,最后清除源内存空间。
    第三:由于老年代垃圾回收器要处理的对象比较多,因此标记的过程和清除的过程都要比年轻代的垃圾回收器慢。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 2月17日
  • 已采纳回答 2月9日
  • 创建了问题 2月9日

悬赏问题

  • ¥15 各位请问平行检验趋势图这样要怎么调整?说标准差差异太大了
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题
  • ¥15 wpf界面一直接收PLC给过来的信号,导致UI界面操作起来会卡顿
  • ¥15 init i2c:2 freq:100000[MAIXPY]: find ov2640[MAIXPY]: find ov sensor是main文件哪里有问题吗
  • ¥15 运动想象脑电信号数据集.vhdr
  • ¥15 三因素重复测量数据R语句编写,不存在交互作用
  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab