一、LockSupport工具类
1.该类的主要作用
- 挂起和唤醒线程,该工具类是创建锁和其他同步类的基础。
- LockSupport类与每个使用它的线程都会关联一个许可证,默认情况下调用LockSupport类的方法的线程是不持有许可证的。LockSupport使用Unsafe类进行实现的。
2.void park()方法
- 如果调用park方法的线程已经拿到了与LockSupport关联的许可证,则调用LockSupport.park()时会马上返回,否则调用线程会禁止参与线程的调度,也就是会被阻塞挂起
- 下面的代码只会输出"begin park!,然后当前线程被挂起,这是因为在默认情况下调用线程是不持有许可证的
package com.ruigege.LockSourceAnalysis6;
import java.util.concurrent.locks.LockSupport;
public class Test1 {
public static void main(String[] args) {
System.out.println("begin park!");
LockSupport.park();
System.out.println("end park");
}
}
- 其他线程调用unpark(Thread thread)方法并且将当前线程作为参数时,调用park方法而被阻塞的线程就会被返回。另外,如果其他线程调用了阻塞线程的interrupt()方法时,设置了中断标志或者线程被虚假唤醒,则阻塞线程也会返回,所以在调用park方法时最好也是用循环条件的判断方式。需要注意的是,因为调用park方法而被阻塞的线程被其他线程中断而返回时并不会抛出InteruptedException异常
3.void unpark(Thread thread)方法
package com.ruigege.LockSourceAnalysis6;
import java.util.concurrent.locks.LockSupport;
public class Test2 {
public static void main(String[] args) {
System.out.println("李天阳");
LockSupport.unpark(Thread.currentThread());
LockSupport.park();
System.out.println("end park");
}
}
- 当一个线程调用unpark时,如果参数thread线程没有持有thread与LockSupport类关联的许可证,则让thread线程持有,如果thread之前因为调用park()而被挂起,则调用upark之后,该线程会被唤醒。如果thread之前没有调用park,则调用unpark方法后,再调用park方法,其会立刻返回。
二、源码:
- 所在包:com.ruigege.ConcurrentListSouceCodeAnalysis5
https://github.com/ruigege66/ConcurrentJava
- 欢迎关注微信公众号:傅里叶变换,个人账号,仅用于技术交流