在回答为什么老年代垃圾回收比年轻代垃圾回收慢的时候,答案里面写到“因为新生代标记存活对象很快,因为新生代存活对象很少;而老年代存活对象很多,在并发标记阶段追踪对象时间成本大”。
但是,在标记存活对象的时候,不是要遍历所有的对象吗,来判断它们是否从根源上被GC roots引用吗,这样的话,它们都是O(n)的时间复杂度,应该时间成本差不多。
还有一个问题,这俩个回收机制都是标记存活对象吗,像上面说的,标记对象,无论垃圾还是存活对象都要遍历全部对象,因此标记存活对象和标记垃圾对象有什么意义呢?这两个应该是等价的。