线程.wait()
当一个线程调用 线程.wait()
时,它会释放对象的锁,让其他线程可以获得这个锁并执行相应的同步代码块,同时,如果未配置超时时间,该线程会无限期等待,直到接收到线程.notify()
信号,注意,一般情况下要在同步代码块中执行。
线程.notify()
当一个线程调用 线程.notify()
时,它会给线程发送一个信号,让其在线程.notify()
卡住的地方继续执行,注意,一般情况下要在同步代码块中执行。
示例
下面是一个演示线程间通讯的示例,在一个定时任务中达成某个条件时,通知主线程继续执行,同时关闭该定时任务:
public static void main(String[] args) throws InterruptedException {
final Thread main = Thread.currentThread();
main.setName("main thread");
// 创建一个默认定时任务
ScheduledThreadPoolExecutor executor = new ScheduledThreadPoolExecutor(
5, // 核心线程数
new ThreadPoolExecutor.CallerRunsPolicy() // 队列满后的拒绝策略
);
AtomicInteger flag = new AtomicInteger(0);
// 执行定时任务
final ScheduledFuture<?> queryTask = executor.scheduleAtFixedRate(() -> {
// 在这里执行您的定时任务逻辑
final int i = flag.addAndGet(1);
log.info("定时任务执行了1!flag={}", i);
if (i == 5) {
synchronized (main) {
System.out.println("通知主线程取消该任务");
main.notify();
}
}
}, 0, 3, TimeUnit.SECONDS);
final ScheduledFuture<?> printTask = executor.scheduleAtFixedRate(() -> {
// 在这里执行您的定时任务逻辑
log.info("定时任务执行了2!");
}, 0, 3, TimeUnit.SECONDS);
log.info("main wait");
synchronized (main) {
/**
*
主线程在执行 main.wait() 进入等待状态后,确实会释放 main 对象的锁,而不是一直占用锁。
这是 Java 中 wait() 方法的特性之一。
当一个线程调用 wait() 方法时,它会释放对象的锁,让其他线程可以获得这个锁并执行相应的同步代码块。
*/
main.wait();
}
log.info("main 活了");
// 取消定时任务
queryTask.cancel(true);
log.info("scheduledFuture被取消");
}
运行结果:
11:14:50.838 [main thread] INFO MyTaskConfig - main wait
11:14:50.838 [pool-1-thread-2] INFO MyTaskConfig - 定时任务执行了2!
11:14:50.838 [pool-1-thread-1] INFO MyTaskConfig - 定时任务执行了1!flag=1
11:14:53.845 [pool-1-thread-1] INFO MyTaskConfig - 定时任务执行了2!
11:14:53.845 [pool-1-thread-2] INFO MyTaskConfig - 定时任务执行了1!flag=2
11:14:56.841 [pool-1-thread-2] INFO MyTaskConfig - 定时任务执行了1!flag=3
11:14:56.842 [pool-1-thread-3] INFO MyTaskConfig - 定时任务执行了2!
11:14:59.841 [pool-1-thread-4] INFO MyTaskConfig - 定时任务执行了1!flag=4
11:14:59.841 [pool-1-thread-1] INFO MyTaskConfig - 定时任务执行了2!
11:15:02.848 [pool-1-thread-2] INFO MyTaskConfig - 定时任务执行了2!
11:15:02.848 [pool-1-thread-4] INFO MyTaskConfig - 定时任务执行了1!flag=5
通知主线程取消该任务
11:15:02.848 [main thread] INFO MyTaskConfig - main 活了
11:15:02.848 [main thread] INFO MyTaskConfig - scheduledFuture被取消
11:15:05.835 [pool-1-thread-2] INFO MyTaskConfig - 定时任务执行了2!
11:15:08.843 [pool-1-thread-2] INFO MyTaskConfig - 定时任务执行了2!
11:15:11.836 [pool-1-thread-2] INFO MyTaskConfig - 定时任务执行了2!