package com.netinfo.demo.thread.condition;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;
/**
* @author:luzaichun
* @Date:2019/10/20
* @Time:15:54
**/
public class ConditionTest {
public static void main(String[] args) {
ReentrantLock lock = new ReentrantLock();
Condition condition1 = lock.newCondition();
Condition condition2 = lock.newCondition();
Thread t1 = new Thread(new Runnable() {
@Override
public void run() {
try {
lock.lock();
System.out.println("进入t1锁。。。。");
condition1.await();
System.out.println("t1继续执行。。。。");
System.out.println("t1..end!!!");
} catch (InterruptedException e) {
e.printStackTrace();
}finally {
System.out.println("t1执行解锁。。。。。");
lock.unlock();
}
}
});
Thread t2 = new Thread(new Runnable() {
@Override
public void run() {
try {
lock.lock();
System.out.println("进入t2锁。。。。");
Thread.sleep(1000);
condition1.signal();
condition2.await();
System.out.println("t2继续执行。。。");
System.out.println("t2....end");
} catch (InterruptedException e) {
e.printStackTrace();
}finally {
lock.unlock();
}
}
});
t1.start();
t2.start();
}
}
输出结果:
进入t1锁。。。。
进入t2锁。。。。
t1继续执行。。。。
t1..end!!!
t1执行解锁。。。。。
在之前我们使用java的wait()方法实现等待时候,如果有多处wait等待,那么我们只能使用notify()随机唤醒某个等待的线程,或者使用notifyAll()唤醒所有等待的线程。没办法更精准的控制唤醒操作。
通过使用ReentrantLock加锁,配合Condition的await()和signal()方法,可以更细粒度控制等待和唤醒操作。