可以使用synchronized关键字和wait()、notify()方法来实现两个线程交替打印。
下面是一个简单的例子,其中A线程打印奇数,B线程打印偶数。
public class AlternatePrint {
private int count = 1;
private final Object lock = new Object();
public static void main(String[] args) {
AlternatePrint alternatePrint = new AlternatePrint();
Thread threadA = new Thread(() -> alternatePrint.printOdd());
Thread threadB = new Thread(() -> alternatePrint.printEven());
threadA.start();
threadB.start();
}
public void printOdd() {
while (count <= 100) {
synchronized (lock) {
if (count % 2 != 0) {
System.out.println(Thread.currentThread().getName() + ": " + count);
count++;
lock.notify(); // 唤醒等待的线程
} else {
try {
lock.wait(); // 当前线程等待
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
}
public void printEven() {
while (count <= 100) {
synchronized (lock) {
if (count % 2 == 0) {
System.out.println(Thread.currentThread().getName() + ": " + count);
count++;
lock.notify(); // 唤醒等待的线程
} else {
try {
lock.wait(); // 当前线程等待
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
}
}
在上面的例子中,使用一个共享的lock对象作为锁,每个线程通过synchronized(lock)来获取锁对象。当count为奇数时,A线程打印并增加count,然后调用lock.notify()方法唤醒正在等待的B线程。当count为偶数时,B线程打印并增加count,然后调用lock.notify()方法唤醒正在等待的A线程。如果count的值不符合当前线程的打印条件时,当前线程调用lock.wait()方法进入等待状态,直到被唤醒。
需要注意的是,lock.wait()和lock.notify()方法只能在synchronized块中调用,否则会抛出IllegalMonitorStateException异常。同时,线程的启动顺序不确定,所以A和B线程的打印顺序可能会有不同。