(二十二)多线程的等待唤醒机制
0 线程状态
每个线程都有6中状态,新生,运行,阻塞,死亡,睡眠,等待。在这些状态中,线程是可以相互转化的。
1 等待唤醒机制
等待唤醒机制就是线程由 wait()等待状态–>notify()被唤醒状态。当线程进入等待状态,线程就不会在运行了,必须由其他线程来唤醒他,它才可以继续向下运行。就比如生产者和消费这模型:
- 消费者线程:提出需求,进行等待wait(或许代码不会执行)
- 生产者线程:完成需求,唤醒消费者线程notify
- 消费者线程:需求被满足,继续执行之后代码。
- 注意:生产者和消费者线程必须保证线程的同步性,使得等待和唤醒只有一个在执行。即需要同一个锁对象才可以调用wit和notify方法。
2 线程等待与唤醒的方法
wait的计时等待
- sleep(time)线程睡眠(等待)time时间后继续执行
- wait(time)线程在等待time,在此期间,如果没有被notify唤醒,那么他就会在时间耗尽之后自动醒来
notify唤醒机制 - notify()只能随机唤醒一个在等待的线程
- notifyall()唤醒所有等待的线程
3 线程之间的通信—等待与唤醒机制
等待唤醒机制可以实现线程对同一资源使用,而不会产生任何冲突。
4 生产者与消费者模型例子。消费者需要吃包子,生产者生产包子满足消费者需求。
过程:消费者首先判断是否有包子可以吃,如果有,那么就吃包子;如果没有,就需要等待生产者生产包子,当生产者生产出来了包子,那么就告知消费者可以吃包子了。这样一直循环,以便方便看见效果。
①首先定义一个资源类对象:包子。也就是生产者和消费者需要使用的锁对象。
public class Baozi {
//一个状态。判断是否有包