![]() ![]() |
|
LockFree结构开发注意事项 | |
作者:佚名 文章来源:不详 点击数 更新时间:2008/10/22 21:33:20 文章录入:杜斌 责任编辑:杜斌 | |
|
|
考试大测试显示,无锁结构在线程数接近内核实际数量的时候表现才优于有锁结构。而在大量线程工作时候效果不佳。因为内存分配使用的是数组结构而不是单链表结构,理论上,每次操作都和整个数组相关,因此会造成数个线程的原子操作都在等待一个数组的完成,产生大量垃圾代码,影响了执行效率。而在线程数量较少的情况下,锁的开销会比垃圾代码执行的开销大。 下面是DCAS利用CAS进行模拟的一个方法: bool cas(volatile void** x, void* new_x, void* old_x); bool dcas(volatile void** x, void* new_x, void* old_x, volatile void** y, void* new_y, void* old_y) { if (old_x == DCAS_BUSY_VAL) return false; if (!cas(x, DCAS_BUSY_VAL, old_x)) return false; if (!cas(y, new_y, old_y)) { x = old_x; return false; } x = new_x; return true; } 基本模拟思路是在对y变量进行更新之前,用一个DCAS_BUSY_VAL的变量将x变量锁定,然后就可以安全更新y变量,再安全更新x变量。其他的k-compare-and-k-swap都可以用这个思路实现。 来源:考试大 |
|
![]() ![]() |