zoukankan      html  css  js  c++  java
  • 线程按序交替

    /*
     * Copyright (c) XXX Corp.
     * All Rights Reserved.
     */
    
    import java.util.concurrent.ExecutionException;
    import java.util.concurrent.locks.Condition;
    import java.util.concurrent.locks.Lock;
    import java.util.concurrent.locks.ReentrantLock;
    
    /**
     * Main.
     *
     * @author Feng Yongkang, 2020/10/26
     * @version XXX v1.0
     */
    public class Main {
        public static void main(String[] args) throws InterruptedException, ExecutionException {
            AlternateDemo alternateDemo = new AlternateDemo();
            new Thread(() -> {
                for (int i = 0; i < 5; i++) {
                    alternateDemo.loop1();
                }
            }, "线程A").start();
            new Thread(() -> {
                for (int i = 0; i < 5; i++) {
                    alternateDemo.loop2();
                }
            }, "线程B").start();
            new Thread(() -> {
                for (int i = 0; i < 5; i++) {
                    alternateDemo.loop3();
                }
            }, "线程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(); public void loop1() { lock.lock(); try { if (number != 1) { condition1.await(); } System.out.println(Thread.currentThread().getName()); number = 2; condition2.signal(); } catch (InterruptedException e) { e.printStackTrace(); } finally { lock.unlock(); } } public void loop2() { lock.lock(); try { if (number != 2) { condition2.await(); } System.out.println(Thread.currentThread().getName()); number = 3; condition3.signal(); } catch (InterruptedException e) { e.printStackTrace(); } finally { lock.unlock(); } } public void loop3() { lock.lock(); try { if (number != 3) { condition3.await(); } System.out.println(Thread.currentThread().getName()); number = 1; condition1.signal(); } catch (InterruptedException e) { e.printStackTrace(); } finally { lock.unlock(); } } }
  • 相关阅读:
    strcpy
    Apple Swift中英文开发资源集锦[apple swift resources]
    c/c++指针总结[pointer summary]
    TestPointer
    66. 有序数组构造二叉搜索树[array to binary search tree]
    HDU 2112 HDU Today
    HDU 3790 最短路径问题
    HDU 2544 最短路
    模拟赛 Problem 3 经营与开发(exploit.cpp/c/pas)
    模拟赛 Problem 2 不等数列(num.cpp/c/pas)
  • 原文地址:https://www.cnblogs.com/xiaoeyu/p/13880597.html
Copyright © 2011-2022 走看看