三个线程轮询数据ABC

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.LinkedBlockingDeque;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;

public class ThreadChange {

    public static void main(String[] args) {
        method();
    }

    private static void method() {
        CountDownLatch count = new CountDownLatch(30);

        ThreadPoolExecutor pool = new ThreadPoolExecutor(3, 3, 0, TimeUnit.SECONDS, new LinkedBlockingDeque<>(32));

        pool.execute(() -> {
            while (true) {
                if (count.getCount() == 0) {
                    break;
                }
                if (count.getCount() % 3 == 0) {
                    System.out.println("A");
                    count.countDown();
                }
            }
        });

        pool.execute(() -> {
            while (true) {
                if (count.getCount() == 0) {
                    break;
                }
                if (count.getCount() % 3 == 2) {
                    // 倒数的   所以取余等于2的时候是B
                    System.out.println("B");
                    count.countDown();
                }
            }
        });

        pool.execute(() -> {
            while (true) {
                if (count.getCount() == 0) {
                    break;
                }
                if (count.getCount() % 3 == 1) {
                    // 倒数的   所以取余等于1的时候是C
                    System.out.println("C");
                    count.countDown();
                }
            }
        });

    }

}
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

public class ThreadChange2 {
    private static Lock lock = new ReentrantLock();
    private static int count = 0;
    private static Condition A = lock.newCondition();
    private static Condition B = lock.newCondition();
    private static Condition C = lock.newCondition();

    public static void main(String[] args) {

        new Thread(() -> {
            lock.lock();
            try {
                for (int i = 0; i < 10; i++) {
                    while (count % 3 != 0) {
                        A.await(); //如果不满足while条件,将本线程挂起    此时会释放lock,将task加入到等待队列
                    }
                    System.out.print("A");
                    count++;
                    B.signal(); // A线程执行后,唤醒下一个线程B
                }
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                lock.unlock();
            }
        }).start();

        new Thread(() -> {
            lock.lock();
            try {
                for (int i = 0; i < 10; i++) {
                    while (count % 3 != 1) {
                        B.await();//如果不满足while条件, 将本线程挂起   此时会释放lock,将task加入到等待队列
                    }
                    System.out.print("B");
                    count++;
                    C.signal();// B线程执行后,唤醒下一个线程C
                }
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                lock.unlock();
            }
        }).start();

        new Thread(() -> {
            lock.lock();
            try {
                for (int i = 0; i < 10; i++) {
                    while (count % 3 != 2) {
                        C.await();//如果不满足while条件, 将本线程挂起   此时会释放lock,将task加入到等待队列
                    }
                    System.out.println("C");
                    count++;
                    A.signal();// C线程执行后,唤醒下一个线程A
                }
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                lock.unlock();
            }
        }).start();

    }

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值