1、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");
}
}
19.1
-
其余线程调用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");
}
}
19.2
-
当一个线程调用unpark时,若是参数thread线程没有持有thread与LockSupport类关联的许可证,则让thread线程持有,若是thread以前由于调用park()而被挂起,则调用upark以后,该线程会被唤醒。若是thread以前没有调用park,则调用unpark方法后,再调用park方法,其会马上返回。
2、源码:
-
所在包:com.ruigege.ConcurrentListSouceCodeAnalysis5
-
https://github.com/ruigege66/ConcurrentJava
-
-
-
欢迎关注微信公众号:傅里叶变换,我的帐号,仅用于技术交流