CLH自旋锁与MCS自旋锁有什么区别?
网友回复
CLH自旋锁(公平) 作者:CLH:Craig,Landin and Hagersten。 锁的名称都来源于发明人的名字首字母 CLH自旋锁是一种基于隐式链表(节点里面没有next指针)的可扩展、高性能、公平的自旋锁,申请线程只在本地变量上自旋,它不断轮询前驱的状态,如果发现前驱释放了锁就结束自旋。CLH队列锁的优点是空间复杂度低(如果有n个线程,L个锁,每个线程每次只获取一个锁,那么需要的存储空间是O(L+n),n个线程有n个。myNode,L个锁有L个tail),CLH的一种变体被应用在了JAVA并发框架中。 CLH在SMP系统结构下该法是非常有效的。但在NUMA系统结构下,每个线程有自己的内存,如果前趋结点的内存位置比较远,自旋判断前趋结点的locked域,性能将大打折扣。
示例代码:
import java.util.concurrent.atomic.AtomicReference; public class HelloWorld { public static void main(String[] args) throws InterruptedException { CLHLock lock=new CLHLock(); Runnable runnable=new Runnable() { @Override public void run() { try { lock.lock(); System.out.println(Thread.currentThread().getName()+" 获得锁 "); //前驱释放,do own work Thread.sleep(5000); System.out.println(Thread.currentThread().getName()+" 释放锁 "); lock.unlock(); } catch (InterruptedException e) { e.printStackTrace(); } } }; Thread t1=new Thread(runnable,"线程1"); Thread t2=new Thread(runnable,"线程2"); Thread t3=new Thread(runnable,"线程3"); t1.start(); t2.start(); t3.start(); } } /** * Created by qindongliang on 2018/8/5. */ class CLHLock { class Node{ //false代表没人占用锁 volatile boolean locked=false; } //指向最后加入的线程 final AtomicReference<Node> tail=new AtomicReference<>(new Node()); //使用ThreadLocal保证每个线程副本内都有一个Node对象 final ThreadLocal<Node> current; public CLHLock(){ //初始化当前节点的node current=new ThreadLocal<Node>(){ @Override protected Node initialValue() { return new Node(); } }; } public void lock() throws InterruptedException { ...
点击查看剩余70%
腾讯混元模型广场里都是混元模型的垂直小模型,如何api调用?
为啥所有的照片分辨率提升工具都会修改照片上的图案细节?
js如何在浏览器中将webm视频的声音分离为单独音频?
微信小程序如何播放第三方域名url的mp4视频?
ai多模态大模型能实时识别视频中的手语为文字吗?
如何远程调试别人的chrome浏览器获取调试信息?
为啥js打开新网页window.open设置窗口宽高无效?
浏览器中js的navigator.mediaDevices.getDisplayMedia屏幕录像无法录制SpeechSynthesisUtterance产生的说话声音?
js中mediaRecorder如何录制window.speechSynthesis声音音频并下载?
python如何直接获取抖音短视频的音频文件url?