6.1 并发标记算法
用Prev指针指向上一次并发处理后的地址,用Next指向并发标记开始之前内存已经分配成功的地址。
并发标记结束后,只需要把Prev指针设置为Next指针,即可开始新一轮的标记处理。
并发标记引入两个位图 PrevBitMap 和 NextBitMap ,来指示哪块内存已经使用,哪块未使用
PrevBitMap 记录prev指针之前内存的标记状况,NextBitMap标识整个内存到next指针之前的标记状态
发生标记失败,就会丢失上一次对Prev指针之前所有内存的标记状况
并发标记结束后,NextBitMap标记了分区对象存活的情况,黑色区域表示堆分区中对应的对象还活着
6.2.1 三色标记法
白色: 表示还没有被收集器标记的对象
灰色 : 表示自身已经被标记到,但其拥有的field字段引用到的其他对象还没有被处理
黑色: 表示自身已经被标记到,且对象本身拥有的field引用到的对象也已经被标记
mutator线程:在垃圾收集器的术语中被称为Java应用线程。
对象在并发标记阶段,会被漏标的充分必要条件