一、 LockSupport 的基本使用
使⽤ LockSupport 也可以使线程休眠和唤醒,它包含两个主要的⽅法:
a. LockSupport.park():休眠当前线程。
b. LockSupport.unpark(线程对象):唤醒某⼀个指定的线程。
LockSupport ⽆需配和 synchronized 使⽤。
import java.util.concurrent.locks.LockSupport;
public class LockSupport1 {
public static void main(String[] args) throws InterruptedException {
//线程1:LockSupport 休眠 park
Thread t1=new Thread(()->{
System.out.println("线程1:开始执行");
LockSupport.park();
System.out.println("线程1:结束执行");
},"线程1");
t1.start();
Thread t2=new Thread(()->{
System.out.println("线程2:开始执行");
LockSupport.park();
System.out.println("线程2:结束执行");
},"线程2");
t2.start();
Thread t3=new Thread(()->{
System.out.println("线程3:开始执行");
LockSupport.park();
System.out.println("线程3:结束执行");
},"线程3");
t3.start();
Thread.sleep(1000);
LockSupport.unpark(t1);
Thread.sleep(1000);
LockSupport.unpark(t2);
Thread.sleep(1000);
LockSupport.unpark(t3);
}
}
二、 LockSupport 的扩展
2.1LockSupport.parkUntil(long)
与wait(long timeout)类似,设置的时间为最大等待时间
import java.time.LocalDateTime;
import java.util.concurrent.locks.LockSupport;
public class LockSupport2 {
public static void main(String[] args) {
Thread t1=new Thread(()->{
System.out.println("线程1:开始执行 |"+ LocalDateTime.now());
LockSupport.parkUntil(System.currentTimeMillis()+1000);
System.out.println("线程1:结束执行 |"+LocalDateTime.now());
});
t1.start();
}
}
2.2LockSupport和Interrupt
LockSupport不会直接抛出异常,但是也可以监听到Interrupt的通知,结束执行。
import java.time.LocalDateTime;
import java.util.concurrent.locks.LockSupport;
public class LockSupport3 {
public static void main(String[] args) throws InterruptedException {
Thread t1=new Thread(()->{
Thread current = Thread.currentThread();
System.out.println("线程终止状态:" + current.isInterrupted()+" " + LocalDateTime.now());
LockSupport.park();
System.out.println("线程终止状态:" + current.isInterrupted()+" " + LocalDateTime.now());
});
t1.start();
Thread.sleep(1000);
System.out.println("终止线程");
t1.interrupt();
}
}
2.3LockSupport与Object的wait/notify
a. LockSupport不需要加锁使用,而wait需要;
b. LockSupport可以指定一个线程进行唤醒,而notify不行;
c. LockSupport不会直接排除Interrupt异常,而wait会;
d. LockSupport的unpark()方法可以先于park()调用,不需要担心线程间的执行先后顺序。