博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CountDownLatch:闭锁
阅读量:4295 次
发布时间:2019-05-27

本文共 614 字,大约阅读时间需要 2 分钟。

线程是如何阻塞以及唤醒的呢?

这里要提出LockSupport类,其有两个重要的方法:

//唤醒线程(底层实现依赖于操作系统)public static void unpark(Thread thread);//阻塞当前线程(底层实现依赖于操作系统)public static void park(Object blocker)

unpark函数可以先于park调用。unpark函数为线程提供“许可(permit)”,线程调用park函数则等待“许可”,如果已经有许可,那么线程会马上再继续运行。

await()

CountDownLatch的await()方法,其执行过程是:

1.addWaiter
创建一个SHARED节点对象,并加入到队列尾部(如果在这之前没有任何节点,要先创建一个head节点)
2.执行等待
2.1 获取步骤1节点的上一个节点。
2.2 如果上一个节点是head节点,且已经没有执行中的任务,阻塞结束,返回。
2.3 如果不是,await方法所在的线程被阻塞(LockSupport.park(this); )。

countDown()

调用tryReleaseShared方法对计数减一(使用CAS乐观锁),如果还有未完成的任务,则结束countDown方法。如果全部任务执行完成,则调用unparkSuccessor方法解除阻塞(LockSupport.unpark(s.thread); )。

转载地址:http://xebws.baihongyu.com/

你可能感兴趣的文章
openstack报错解决一
查看>>
openstack报错解决二
查看>>
linux source命令
查看>>
openstack报错解决三
查看>>
乙未年年终总结
查看>>
子网掩码
查看>>
第一天上班没精神
查看>>
启动eclipse报错:Failed to load the JNI shared library
查看>>
eclipse安装插件的两种方式在线和离线
查看>>
linux下源的相关笔记(suse)
查看>>
linux系统分区文件系统划分札记
查看>>
Linux(SUSE 12)安装Tomcat
查看>>
Linux(SUSE 12)安装jboss4并实现远程访问
查看>>
Neutron在给虚拟机分配网络时,底层是如何实现的?
查看>>
netfilter/iptables全攻略
查看>>
Overlay之VXLAN架构
查看>>
Eclipse : An error occurred while filtering resources(Maven错误提示)
查看>>
在eclipse上用tomcat部署项目404解决方案
查看>>
web.xml 配置中classpath: 与classpath*:的区别
查看>>
suse如何修改ssh端口为2222?
查看>>