Java架构师交流群:793825326
java版本:jdk1.8
IDE:idea 18
之前的一篇博客(https://blog.csdn.net/dap769815768/article/details/96712257)讲了wait、notify\notifyAll的使用,实际上目前我们比较推荐的方式是用Condition的await、signal\signalAll来实现类似的功能。
添加一个测试类Test:
private Lock lock=new ReentrantLock(); private Condition condition=lock.newCondition(); System.out.println(Thread.currentThread().getId() + "执行"); System.out.println(Thread.currentThread().getId() + "start"); System.out.println(Thread.currentThread().getId() + "end"); public synchronized void releaseOne()
写一段测试代码:
Thread thread1= new Thread(() -> t.start()); Thread thread2= new Thread(() -> t.start());
这和之前使用wait、notify\notifyAll这套方案实现的效果一样。
如果单纯从这个例子来看,它们之间并没有什么区别,Condition的优势也没有体现出来。实际上Condition可以实现更细粒度的控制。看下面的代码:
private Lock lock=new ReentrantLock(); private Condition condition1=lock.newCondition(); private Condition condition2=lock.newCondition(); System.out.println(Thread.currentThread().getId() + "执行"); System.out.println(Thread.currentThread().getId() + "start"); System.out.println(Thread.currentThread().getId() + "end"); System.out.println(Thread.currentThread().getId() + "执行"); System.out.println(Thread.currentThread().getId() + "start"); System.out.println(Thread.currentThread().getId() + "end"); public synchronized void release1() public synchronized void release2()
测试代码如下:
Thread thread1= new Thread(() -> t.start1()); Thread thread2= new Thread(() -> t.start2());
它的执行结果:
14执行 15执行 15start 15end 14start 14end
在这个例子中,采用Condition的方式,显然比之前控制地更精确了。
|