与互斥锁的相比,在获取锁失败的时候不会使得线程阻塞而是一直自旋尝试获取锁。当线程等待锁的时候,CPU不能做其他事情,而是一直处于轮询忙等的状态,直到获取这个锁为止 。
因此,自旋锁是比较耗费CPU的。
std::atomic_flag lock = ATOMIC_FLAG_INIT;void test()
{
while (lock.test_and_set(std::memory_order_acquire)) {} //获得锁...... //其他操作
lock.clear(std::memory_order_release); //释放锁
}