1 对象等待集
1.1 背景:
一个线程频繁加锁解锁,占用CPU,导致其他线程无法获取到CPU,其他进程“饿死”。
1.2 wait/notify
让程序员有一定的办法干预线程调度。
线程的调度本来是完全由内核全权负责的,但是这样的抢占式执行可能会带来很多问题(线程饿死)。
wait方法:当操作条件不成熟,就等待。
notify方法:当操作条件成熟时,通知指定的线程来工作。
wait 调用的时候就会阻塞,一直阻塞到有其他线程调用对应的notify为止。
wait和notify 都必须搭配 synchronized来使用。
wait本质做了三件事
1.释放锁
2.等待通知 前两个条件是原子的,为了避免竞态条件问题
3.尝试重新获取锁并继续执行
wait和sleep的区别
wait/notify 机制 一定程度的影响线程调度
sleep 是让当前线程休眠