面试题:多线程交替打印数字
代码概述
这个Java程序使用了三个线程(t1
, t2
, t3
)和三个信号量(first
, second
, third
)来实现交替打印数字1、2、3的功能。每个线程负责打印一个数字,并通过信号量来控制线程的执行顺序。
代码结构
-
信号量初始化:
first
,second
,third
三个信号量分别用于控制三个线程的执行顺序。- 初始时,
first
信号量的许可数为0,表示t1
线程需要等待。
-
线程定义:
t1
线程:打印数字1,然后唤醒t2
线程,并使自己进入等待状态。t2
线程:等待t1
线程的唤醒信号,打印数字2,然后唤醒t3
线程。t3
线程:等待t2
线程的唤醒信号,打印数字3,然后唤醒t1
线程。
-
线程启动:
- 三个线程依次启动,开始执行各自的逻辑。
代码实现
package threadQuestion;
import java.util.concurrent.Semaphore;
public class AlternativePrintPlus {
public static void main(String[] args) {
final Semaphore first = new Semaphore(0);
final Semaphore second = new Semaphore(0);
final Semaphore third = new Semaphore(0);
final Thread t1 = new Thread(() -> {
for (; ; ) {
try {
System.out.println('1');
Thread.sleep(1000);
second.release(); // 唤醒线程2
first.acquire(); // 当前线程休眠
} catch (InterruptedException ex) {
ex.printStackTrace();
}
}
}, "Print 1");
final Thread t2 = new Thread(() -> {
for (; ; ) {
try {
second.acquire(); // 当前线程休眠
System.out.println(