zoukankan      html  css  js  c++  java
  • 线程间通讯(交替打印ABC)

    package com.kaibing.thread;
    
    import java.util.concurrent.locks.Condition;
    import java.util.concurrent.locks.Lock;
    import java.util.concurrent.locks.ReentrantLock;
    
    public class ABCAlternate {
    
        public static void main(String[] args) {
            Alternate alternate = new Alternate();
    
            new Thread(new Runnable() {
                @Override
                public void run() {
                    for (int i=0;i<20;i++){
                        alternate.printA(i);
                    }
                }
            },"A").start();
            new Thread(new Runnable() {
                @Override
                public void run() {
                    for (int i=0;i<20;i++){
                        alternate.printB(i);
                    }
                }
            },"B").start();
            new Thread(new Runnable() {
                @Override
                public void run() {
                    for (int i=0;i<20;i++){
                        alternate.printC(i);
                    }
                }
            },"C").start();
        }
    
    }
    class Alternate{
    
        private int number = 1;
    
        private Lock lock = new ReentrantLock();//
    
        private Condition condition1 = lock.newCondition();
        private Condition condition2 = lock.newCondition();
        private Condition condition3 = lock.newCondition();
    
    
        public void printA(int totalLoop){
    
            lock.lock();//加锁
    
            try{
                if (number != 1){
                    condition1.await();
                }
                System.out.println(Thread.currentThread().getName() + " == 	A	" + "第" + totalLoop + "次循环");
    
                number = 2;
                condition2.signal();//唤醒2
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                lock.unlock();//释放锁
            }
    
        }
    
        public void printB(int totalLoop){
    
            lock.lock();//加锁
    
            try{
                if (number != 2){
                    condition2.await();
                }
                System.out.println(Thread.currentThread().getName() + " == 	B	" + "第" + totalLoop + "次循环");
    
                number = 3;
                condition3.signal();//唤醒3
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                lock.unlock();//释放锁
            }
    
        }
        public void printC(int totalLoop){
    
            lock.lock();//加锁
    
            try{
                if (number != 3){
                    condition3.await();
                }
                System.out.println(Thread.currentThread().getName() + " == 	C	" + "第" + totalLoop + "次循环");
    
                number = 1;
                condition1.signal();//唤醒1
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                lock.unlock();//释放锁
            }
    
        }
    
    
    }
  • 相关阅读:
    4408: [Fjoi 2016]神秘数
    UOJ #35. 后缀排序[后缀数组详细整理]
    POJ 2887 Big String
    搜索过滤grep(win下为findstr)
    解决putty自动断开的问题
    > >> 将错误输出到文件
    环境变量
    端口被占用,查看并杀死占用端口的进程
    查找文件路径find
    【vim使用】
  • 原文地址:https://www.cnblogs.com/kaibing/p/9258336.html
Copyright © 2011-2022 走看看