为什么有等待-通知机制?
首先,设想这样一种场景:一个线程的执行需要满足某些条件,当条件不满足时就通过一个循环不断尝试,直到条件满足。
这个场景下存在一个明显的缺点,就是线程不断地尝试获取所需的条件,这个循环的过程会白白浪费CPU资源,降低系统性能。
等待-通知机制是一种优化策略,其核心思想就是:当线程所需条件不满足时,就阻塞该线程,之后当条件满足时再通知线程,以此提高硬件资源的利用率
Java 中的实现
在 Java 中实现等待-通知机制,一种经典的做法是使用 synchronized + wait() + notify() / notifyAll()
我们可以通过一个经典的面试题来讲解这种用法:
请使用等待-通知机制实现两个线程交替打印 1~100
这个问题的解法有很多,我这里展示一下我自己的方法:
public class AlternatelyPrint {
private int curNum = 0;
synchronized void printNum(int n) {
// 用 n - curNum 判断是否轮到当前打印数字
while (n - curNum != 1) {
try {
wait(