1. wait方法
当条件不成熟时就等待
运行分为三步: 1.释放锁 2.等到通知 3.收到通知后尝试重新获取锁继续往下执行
wait两种使用方法 1.wait()死等,一直等待notify的通知来 2.wait(time) :等待有上限,如果有notify就会被提前唤醒,如果没有notify那么时间到了就会被唤醒
wait方法必须在synchronized代码内部使用
2. notify方法
当条件成熟时,通知指定线程来工作
notify方法必须在synchronized代码内部使用
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();
}
}
3. wait 和 sleep 的对比
其实理论上 wait 和 sleep 完全是没有可比性的,因为一个是用于线程之间的通信的,一个是让线程阻塞一段时间,唯一的相同点就是都可以让线程放弃执行一段时间。我们还是将两者的对比总结如下:
- wait 之前需要请求锁,而wait执行时会先释放锁,等被唤醒时再重新请求锁。这个锁是 wait 对像上的 monitorlock
- sleep 是无视锁的存在的,即之前请求的锁不会释放,没有锁也不会请求。
- wait 是 Object 的方法
- sleep 是 Thread 的静态方法