12. wait() 和 notify()的区别(对象的等待集)

Java
282
0
0
2022-11-28

1. wait方法

当条件不成熟时就等待

运行分为三步: 1.释放锁 2.等到通知 3.收到通知后尝试重新获取锁继续往下执行

wait两种使用方法 1.wait()死等,一直等待notify的通知来 2.wait(time) :等待有上限,如果有notify就会被提前唤醒,如果没有notify那么时间到了就会被唤醒

wait方法必须在synchronized代码内部使用

img

2. notify方法

当条件成熟时,通知指定线程来工作

notify方法必须在synchronized代码内部使用

img

wait和notify结合:

import java.util.Scanner;

public class ThreadDemo18 {
    public static void main(String[] args) throws InterruptedException {
        Object locker = new Object();
        Thread t1 = new Thread(){
            @Override 
            public void run() {
                synchronized (locker){
                    while (true){
                        try {
                            System.out.println("wait开始");
                            locker.wait();
                            System.out.println("wait结束");
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                        }
                    }
                }
            }
        };
        t1.start();

        Thread t2 = new Thread(){
            @Override 
            public void run() {
                Scanner scanner = new Scanner(System.in);
                System.out.println("输入一个整数继续执行notify");
                int num = scanner.nextInt();
                synchronized (locker){
                    System.out.println("notify开始");
                    locker.notify();
                    System.out.println("notify结束");
                }
            }
        };
        t2.start();

        t1.join();
        t2.join();
    }
}

img

img

3. wait 和 sleep 的对比

其实理论上 wait 和 sleep 完全是没有可比性的,因为一个是用于线程之间的通信的,一个是让线程阻塞一段时间,唯一的相同点就是都可以让线程放弃执行一段时间。我们还是将两者的对比总结如下:

  1. wait 之前需要请求锁,而wait执行时会先释放锁,等被唤醒时再重新请求锁。这个锁是 wait 对像上的 monitorlock
  2. sleep 是无视锁的存在的,即之前请求的锁不会释放,没有锁也不会请求。
  3. wait 是 Object 的方法
  4. sleep 是 Thread 的静态方法