锁只能实现互斥,不能实现线程之间的通讯(能够参看一个线程间通讯的例子http://020618.blog.51cto.com/6098149/1182807),而Condition能够解决这个问题,即便CPU分给了当前的线程,可是当前的线程能够让出CPU,让其它的相称执行,当前线程暂停,当其它的线程执行完后,在通知当前的线程,这样就实现了线程之间的通讯。java
Java5并发库中的Condition的功能相似在传统线程技术中的Object.wait()和Object.notify()的功能,在等待Condition时,容许发生“虚假唤醒”,这一般做为对基础平台语义的让步。对于大多数应用程序,这实际带来的影响很小,由于Condition应该老是在一个循环中等待,并测试正被等待的状态声明。某个实现能够随意移除可能的虚假唤醒,但建议应用程序员老是这些虚假唤醒可能发生,所以,老是在下一个循环中等待。程序员
虽然Condition的功能相似在传统线程技术中的Object.wait()和Object.notify()的功能,可是Condition能够实现synchronizd实现不了的功能。并发
下面看一个Condition的代码例子:实现3个线程时间的交替执行,使main线程唤sub2线程,sub2线程唤醒sub3线程,sub3线程唤醒main线程,如此循环50次。代码以下:ide
- import java.util.concurrent.locks.Condition;
- import java.util.concurrent.locks.Lock;
- import java.util.concurrent.locks.ReentrantLock;
- public class ThreeConditionCommunication {
- public static void main(String[] args) {
- final Business business = new Business();
- new Thread(
- new Runnable() {
- @Override
- public void run() {
- for(int i=1;i<=50;i++){
- business.sub2(i);
- }
- }
- }
- ).start();
- new Thread(
- new Runnable() {
- @Override
- public void run() {
- for(int i=1;i<=50;i++){
- business.sub3(i);
- }
- }
- }
- ).start();
- for(int i=1;i<=50;i++){
- business.main(i);
- }
- }
- /*
- main线程唤sub2线程,sub2线程唤醒sub3线程,sub3线程唤醒main线程,须要三个条件
- */
- static class Business {
- Lock lock = new ReentrantLock();
- Condition condition1 = lock.newCondition();
- Condition condition2 = lock.newCondition();
- Condition condition3 = lock.newCondition();
- private int shouldSub = 1;//刚开始main线程先执行
- public void sub2(int i){//子线程2
- lock.lock();
- try{
- while(shouldSub != 2){
- try {
- condition2.await();//sub2线程在等待主线程
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- for(int j=1;j<=10;j++){
- System.out.println("sub2 thread sequence of " + j + ",loop of " + i);
- }
- shouldSub = 3;//执行完以后通知sub3线程
- condition3.signal();//通知sub3线程开始执行
- }finally{
- lock.unlock();
- }
- }
- public void sub3(int i){//子线程3
- lock.lock();
- try{
- while(shouldSub != 3){//不应sub3线程执行
- try {
- condition3.await();//sub3线程执行
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- for(int j=1;j<=20;j++){
- System.out.println("sub3 thread sequence of " + j + ",loop of " + i);
- }
- shouldSub = 1;//执行完以后通知main线程
- condition1.signal();//main线程开始执行
- }finally{
- lock.unlock();
- }
- }
- public void main(int i){//主线程
- lock.lock();
- try{
- while(shouldSub != 1){//不应main线程执行
- try {
- condition1.await();//main线程等待
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- for(int j=1;j<=100;j++){
- System.out.println("main thread sequence of " + j + ",loop of " + i);
- }
- shouldSub = 2;//main线程通知sub2线程执行
- condition2.signal();//sub2线程按开始执行
- }finally{
- lock.unlock();
- }
- }
- }
- }
程序运行的结果:oop
上面的代码是在 一个线程通讯的例子(http://020618.blog.51cto.com/6098149/1182807)的基础上进行改写的,感兴趣的朋友能够看一下。测试