Condition 控制线程通信

来源:互联网 发布:笔记本电脑咋下载软件 编辑:程序博客网 时间:2024/06/05 02:01

  Condition 接口描述了可能会与锁有关联的条件变量。这些变量在用法上与使用Object.wait 访问的隐式监视器类似,但提供了更强大的功能。需要特别指出的是,单个Lock 可能与多个Condition 对象关联。为了避免兼容性问题,Condition 方法的名称与对应的Object 版本中的不同。
  在Condition 对象中,与wait、notify 和notifyAll 方法对应的分别是await、signal 和signalAll。
  Condition 实例实质上被绑定到一个锁上。要为特定Lock 实例获得Condition 实例,请使用其newCondition() 方法。

编写一个程序,开启 3 个线程,这三个线程的 ID 分别为 A、B、C,每个线程将自己的 ID 在屏幕上打印 10 遍,要求输出的结果必须按顺序显示。
如:ABCABCABC…… 依次递归

public class TestABCAlternate {    public static void main(String[] args) {        AlternateDemo ad = new AlternateDemo();        new Thread(new Runnable() {            @Override            public void run() {                for (int i = 1; i <= 20; i++) {                    ad.loopA(i);                }            }        }, "A").start();        new Thread(new Runnable() {            @Override            public void run() {                for (int i = 1; i <= 20; i++) {                    ad.loopB(i);                }            }        }, "B").start();        new Thread(new Runnable() {            @Override            public void run() {                for (int i = 1; i <= 20; i++) {                    ad.loopC(i);                    System.out.println("-----------------------------------");                }            }        }, "C").start();    }}class AlternateDemo{    private int number = 1; //当前正在执行线程的标记    private Lock lock = new ReentrantLock();    private Condition condition1 = lock.newCondition();    private Condition condition2 = lock.newCondition();    private Condition condition3 = lock.newCondition();    /**     * @param totalLoop : 循环第几轮     */    public void loopA(int totalLoop){        lock.lock();        try {            //1. 判断            if(number != 1){                condition1.await();            }            //2. 打印            for (int i = 1; i <= 1; i++) {                System.out.println(Thread.currentThread().getName() + "\t" + i + "\t" + totalLoop);            }            //3. 唤醒            number = 2;            condition2.signal();        } catch (Exception e) {            e.printStackTrace();        } finally {            lock.unlock();        }    }    public void loopB(int totalLoop){        lock.lock();        try {            //1. 判断            if(number != 2){                condition2.await();            }            //2. 打印            for (int i = 1; i <= 1; i++) {                System.out.println(Thread.currentThread().getName() + "\t" + i + "\t" + totalLoop);            }            //3. 唤醒            number = 3;            condition3.signal();        } catch (Exception e) {            e.printStackTrace();        } finally {            lock.unlock();        }    }    public void loopC(int totalLoop){        lock.lock();        try {            //1. 判断            if(number != 3){                condition3.await();            }            //2. 打印            for (int i = 1; i <= 1; i++) {                System.out.println(Thread.currentThread().getName() + "\t" + i + "\t" + totalLoop);            }            //3. 唤醒            number = 1;            condition1.signal();        } catch (Exception e) {            e.printStackTrace();        } finally {            lock.unlock();        }    }}