两个线程交替打印奇偶

经典问题

用两个线程交替打印奇数和偶数问题

问题描述: 有两个线程分别输出奇数和偶数,编写程序使得输出顺序是1, 2, 3, 4, 5, 6, 7, 8, 9, 一直到 100

这是一道笔试题,经常出现,能非常好的考察对并发编程的掌握程度,当然实现方式也是多样的。

思路1 用 synchronized 以及等待通知机制解决

分析如下:

  1. 需要启动两个线程A和B

  2. 共享资源是要打印的数字

  3. 线程A打印奇数,线程B打印偶数,线程A打印完之后通知线程B并等待线程B打印完

  4. 线程A或者B能够收到对方的通知,并继续打印自己的数字

// 互斥资源:要打印的数字
// 互斥锁:共享一把锁即可,如 Object lock = new Object();
// 线程要求的条件:两个线程交替执行
// 何时等待:打印完自己的数字等待对方打印
// 何时通知:打印安自己的数字通知对方打印
public class PrintEvenOdd {
    private static volatile int number = 1;
    private static int MAX = 100;

    public static void main(String[] args) {
        // 互斥锁
        Object lock = new Object();

        Runnable runnable = () -> {
            synchronized (lock) {
                while (number <= MAX) {
                    System.out.println(number++);
                    lock.notifyAll();
                    try {
                        lock.wait();
                    } catch (InterruptedException e) {}
                }

                lock.notifyAll();
            }
        };

        // 启动奇数线程
        new Thread(runnable, "奇数线程").start();

        // 启动偶数线程
        new Thread(runnable, "偶数线程").start();
    }
}

思路2 利用 synchronized 或者 Lock 接口结合判断奇偶的方式

思路1 利用了等待-通知机制,是我认为的最优秀的解决方法了。判断奇偶的思路更容易理解。

思路3 可以利用 Lock 和 Condition 交替打印

这种方式本质上还是等待-通知机制,也非常棒。

最后更新于

这有帮助吗?