1、使用
LockSupport和CAS操作是java并发包中很多控制机制的基础,都是通过UNSAFE来实现的。
LockSupport是基本的线程阻塞的原语,通过park和unpark来实现线程的阻塞和唤醒。LockSupport的每个使用它的线程都与一个许可(permit)有关,permit是一个0,1的开关,默认是0,unpark会将permit变为1。park会消耗permit,变为0,同是park马上返回。如果再调用一次park,则会阻塞再这里,直到unpark将permit变为1。
permit最多只有1个,重复调用unpark不会累计。
void park()
void unpark(Thread thread)
2、其他
LockSupport中有如下方法需要特别说明
//记录线程被谁阻塞的parkBlocker的偏移
private static final long parkBlockerOffset;
//记录线程是被谁阻塞的,用于线程监控及分析工具来定位原因
static Object getBlocker(Thread t){}
本文介绍了Java并发包中LockSupport的基本原理与应用。LockSupport利用park和unpark操作实现线程间的阻塞与唤醒,每个线程关联一个许可,通过许可的切换控制线程状态。此外还介绍了线程监控的相关方法。
548

被折叠的 条评论
为什么被折叠?



