前面了解了ReentrantLock的原理,今天来应用一下,使用ReentrantLock实现两个线程的交替打印。
首先定义一个AtomicInteger类型的status变量,用作计数自增,定义一个ReentrantLock锁,定义两个锁条件:奇数条件、偶数条件。
首先通过类型来区分这次打印奇数还是打印偶数,如果是1则进入打印奇数的逻辑,判断计数小于最大值,然后使用非公平锁加锁,判断当前计数是否为偶数,如果是偶数则调用oushu.await()方法,进入等待队列并且释放锁,这时锁被另一个打印偶数的线程获取到,打印出偶数,然后调用oushu.signal()方法唤醒在等待队列中的奇数线程;如果是奇数,则打印奇数后,唤醒偶数线程,获取锁后进行打印。
//使当前线程加入 await() 等待队列中,并释放当锁,当其他线程调用signal()会重新请求锁。与Object.wait()类似。
void await() throws InterruptedException;
//唤醒一个在 await()等待队列中的线程。与Object.notify()相似
void signal();
//唤醒 await()等待队列中所有的线程。与object.notifyAll()相似
void signalAll();