wait/notify/notifyall的使用场景
1.wait使当前线程阻塞,前提是线程必须获得锁,所以一般配合synchronized使用。
2.线程执行wait的时候,会释放当前的锁,然后让出cpu,进入等待状态。
3.wait方法需要被try catch包含。
4.wait/notify/notifyall的使用场景
(1)生产者/消费者模型的实现
注意点:
a.假死
当有多个生产者或者消费者的时候,使用的是notify而不是notifyall,那么有可能唤醒的是同类的,即有可能生产者唤醒的是生产者,消费者唤醒的是消费者。
解决办法:使用notifyall
b.生产者/消费者使用if判断的话会导致程序错乱。
如果生产者是往list数组中存放数据,list数组的最大容量为1,消费者执行的是list.remove(0),如果使用if,有多个消费者的情况下,有可能其中一个消费者执行了remove(0),另一个消费者执行的时候就会报错。
解决的办法:使用while代替if。
(2)future模式的实现
future主要四个类:
Data接口(包含getRequest接口),FutureData实现Data接口,RealData实现Data接口,FutureClient供用户调用。
用户通过FutureClient请求数据的时候,先返回FutureData,在开启一个线程往FutureData中设置RealData的数据,当用户请求调用getRequest的时候,如果数据还没构造好,则调用wait进行阻塞,同时调用while进行轮询查看数据是否准备好(isReay字段,boolean类型),当数据构造好的时候,isReay字段置为true。
参看资料:
https://www.jianshu.com/p/444cbe1691be