夸代扫描,比如说回收短暂代,但是在短暂代当中有一个被一代引用的变量。
这个时候可能会造成了这个变量被回收,程序发生不可与之错误。card table 就是为了预防这种情况的一个数组。
int p = 0;
int* card_table= &p;
card_table[0] = 1;
card_table[1] = 2;
card_table[2] = 3;
card_table表在的索引位 card/32,而card为 2的8次方。而值只有两个为零或者为1,4个字节的0xFFFF的宽度
BOOL gc_heap::find_card(uint32_t* card_table,
size_t& card,
size_t card_word_end,
size_t& end_card)
{
uint32_t* last_card_word;
uint32_t card_word_value;
uint32_t bit_position;
// Find the first card which is set
last_card_word = &card_table [card_word (card)]; // 找到card_table当前索引的地址值,实质上也就是实际地址除以2的13次方之后的值
bit_position = card_bit (card); // 求余数获取到偏移的bit位
card_word_value = (*last_card_word) >> bit_position;// 这个实质上是在set_card的时候复原原值的一个过程card_table[word] = (card_