美文网首页
高并发(14)-CLH队列锁

高并发(14)-CLH队列锁

作者: 残冬十九 | 来源:发表于2020-04-06 21:54 被阅读0次

@TOC

前言

上篇文章讲解了并发中的显式锁与内置锁,今天就讲讲CLH队列锁

什么是CLH队列锁

CLH锁即Craig, Landin, and Hagersten (CLH)

CLH锁也是一种基于链表的可扩展、高性能、公平的自旋锁,线程只需要在本地自旋,查询前驱节点的状态,如果前驱节点释放了锁,就结束自旋。

CLH的原理

因为CLH是一个基于链表的自旋锁,所以CLH也就是个链表。

当一个线程需要获得锁的时候,就会创建一个新的QNode。并将QNode的locked设置为true标识要获取锁,并且调用tail的getAndSet方法,让自己成为队列的尾部,同时获取一个指向前驱节点的myPred。然后就对前驱记节点的locked自旋,一直到前驱节点释放锁(locked为false)

当一个线程释放锁的时候,就将当前节点的locked设为false,并且将前驱节点收回,这时候之后节点就在自旋中检测到了前驱节点的锁释放,然后去获取锁。

CLH队列图

相关文章

网友评论

      本文标题:高并发(14)-CLH队列锁

      本文链接:https://www.haomeiwen.com/subject/sdwiphtx.html