wait()、notify()、notifyAll()(使用前提线程之间是使用synchronized保证线程安全的),这三个方法都是本地的方法,被final修饰,无法被重写。wait()方法让进程释放对象锁进入阻塞状态->notify()用于唤醒一个正在等待相应对象锁的线程,使其进入就绪状态,notifyAll()唤醒所有处于等待对象锁的进程并使他们都处于就绪状态。
每个锁对象都有两个队列:就绪队列存储了已就绪(将要竞争锁)的进程,阻塞队列阻塞了被阻塞的进程,当阻塞进程被唤醒后才会进入就绪队列,等待调度。反之,当一个线程被wait后就会进入阻塞队列,等待被唤醒。
await(),signal(),signalAll()(使用前提进程之间使用Lock保证线程安全)这三个方法都是Condition接口中的方法,相较于wait+notify实现线程间的协作await+signal更能安全和高效的实现进程间协作。
BlockingQueue
Java5提供了一个阻塞队列的接口,虽然是queue的子接口,但是主要用途并不是作为容器。而是进程间通信的工具,生产者进程试图向BlockingQueue中放入元素时,如果该队列已满,则进程被阻塞,当消费者进程试图取出元素时,该队列为空,则进程被阻塞。程序中两个进程通过取入取出可以很好的控制进程的通信。