可以使用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线程的打印顺序可能会有不同。