线程之间除了抢占式调用这种竞争的关系外还有一种合作的关系,如何使多个线程协调一致,有序的完成一件事情,这里就用到了线程的等待唤醒机制。
package com.rxsoft.part11;
//顾客线程和老板线程说,我要什么
//老板线程给顾客线程相应的产品
public class Demo {
public static void main(String[] args) {
Object lock=new Object(); //充当协调者的角色
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("1.告诉老板要的早餐种类和数量。。。");
//进入等待
synchronized (lock){
try {
lock.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
//等待结束后,继续执行
System.out.println("3.拿到老板给的早餐,开始吃");
}
},"顾客线程").start();
new Thread(new Runnable() {
@Override
public void run() {
//等待2秒做早餐
try {
Thread.sleep(2000);
}catch (InterruptedException e){
e.printStackTrace();
}
synchronized (lock){
System.out.println("2.老板做好了,交给顾客。。。");
//通知顾客线程,并将其唤醒,早餐做好了
lock.notify(); //通知顾客线程
}
}
},"老板线程").start();
}
}
两个栈,当顾客线程执行到同步代码块里,lock.wait()会释放锁,本线程会被放到等待池waitset中,该线程不会继续往下走了。然后老板线程会拿到锁,,执行同步代码块中内容后会释放锁。lock.notify()通知等待池waitset中对应锁的线程醒来,然后重新竞争获得cpu,继续往下执行。
wait方法中可以指定等待时间,时间到了以后自动醒来。