java使用wait()和notify()线程间通讯

线程.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 - 定时任务执行了211:14:50.838 [pool-1-thread-1] INFO MyTaskConfig - 定时任务执行了1!flag=1
11:14:53.845 [pool-1-thread-1] INFO MyTaskConfig - 定时任务执行了211: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 - 定时任务执行了211:14:59.841 [pool-1-thread-4] INFO MyTaskConfig - 定时任务执行了1!flag=4
11:14:59.841 [pool-1-thread-1] INFO MyTaskConfig - 定时任务执行了211:15:02.848 [pool-1-thread-2] INFO MyTaskConfig - 定时任务执行了211: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 - 定时任务执行了211:15:08.843 [pool-1-thread-2] INFO MyTaskConfig - 定时任务执行了211:15:11.836 [pool-1-thread-2] INFO MyTaskConfig - 定时任务执行了2

你可能感兴趣的:(java,java)