多线程-开启3个线程,循环打印输出结果ABC

7 篇文章 0 订阅

问题: 开启3个线程,循环打印输出结果ABC (必须按照ABC的顺序显示) 10次
结果:

Thread-0 A
Thread-1 B
Thread-2 C
Thread-0 A
Thread-1 B
Thread-2 C

Semaphore

    private static void testPrintABC5() {
        PrintABC printABC = new PrintABC();
        new Thread(() -> {
            for (int i = 0; i < 2; i++) {
                printABC.printA();
            }
        }).start();
        new Thread(() -> {
            for (int i = 0; i < 2; i++) {
                printABC.printB();
            }
        }).start();
        new Thread(() -> {
            for (int i = 0; i < 2; i++) {
                printABC.printC();
            }
        }).start();
    }

    static class printABC{
        private Semaphore semaphoreA = new Semaphore(1);
        private Semaphore semaphoreB = new Semaphore(0);
        private Semaphore semaphoreC = new Semaphore(0);


        public void printA() {
            try {
                semaphoreA.acquire();
                System.out.println(Thread.currentThread().getName() + " A");
                semaphoreB.release();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }

        public void printB() {
            try {
                semaphoreB.acquire();
                System.out.println(Thread.currentThread().getName() + " B");
                semaphoreC.release();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }

        public void printC() {
            try {
                semaphoreC.acquire();
                System.out.println(Thread.currentThread().getName() + " C");
                semaphoreA.release();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }

Synchronized

    private static void testPrintABC1() {
        new Thread(new PrintABC(0)).start();
        new Thread(new PrintABC(1)).start();
        new Thread(new PrintABC(2)).start();
    }

    static class PrintABC implements Runnable {
        private static final Object lock = new Object();
        private static volatile int count = 0;
        private final int flag;

        public PrintABC(int flag) {
            this.flag = flag;
        }

        @Override
        public void run() {
            for (int i = 0; i < 10; i++) {
                synchronized (lock) {
                    while (count % 3 != flag) {
                        try {
                            lock.wait();
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                        }
                    }
                    System.out.println(Thread.currentThread().getName() + " " + (char) (flag + 'A'));
                    count++;
                    lock.notifyAll();
                }
            }
        }
    }

Lock Condition

    private static void testPrintABC2() {
        new Thread(new PrintABC2(0)).start();
        new Thread(new PrintABC2(1)).start();
        new Thread(new PrintABC2(2)).start();
    }

    static class PrintABC2 implements Runnable {
        public static final Lock lock = new ReentrantLock();
        public static final Condition condition = lock.newCondition();
        private static volatile int count = 0;
        private final int flag;

        public PrintABC2(int flag) {
            this.flag = flag;
        }

        @Override
        public void run() {
            for (int i = 0; i < 10; i++) {
                lock.lock();
                try {
                    while (count % 3 != flag) {
                        try {
                            condition.await();
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                        }
                    }
                    System.out.println(Thread.currentThread().getName() + " " + (char) (flag + 'A'));
                    count++;
                    condition.signalAll();
                } catch (Exception e) {
                    e.printStackTrace();
                } finally {
                    lock.unlock();
                }
            }
        }
    }

Lock Multi Condition

    private static void testPrintABC3() {
        PrintABC3 printABC3 = new PrintABC3();
        new Thread(() -> {
            for (int i = 0; i < 2; i++) {
                printABC3.printA();
            }
        }).start();
        new Thread(() -> {
            for (int i = 0; i < 2; i++) {
                printABC3.printB();
            }
        }).start();
        new Thread(() -> {
            for (int i = 0; i < 2; i++) {
                printABC3.printC();
            }
        }).start();
    }


    static class PrintABC3 {
        private Lock lock = new ReentrantLock();
        private Condition condition1 = lock.newCondition();
        private Condition condition2 = lock.newCondition();
        private Condition condition3 = lock.newCondition();
        private int num = 0;

        public void printA() {
            lock.lock();
            try {
                while (num != 0) {
                    condition1.await();
                }
                System.out.println(Thread.currentThread().getName() + " A");
                num = 1;
                condition2.signal();
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                lock.unlock();
            }
        }

        public void printB() {
            lock.lock();
            try {
                while (num != 1) {
                    condition2.await();
                }
                System.out.println(Thread.currentThread().getName() + " B");
                num = 2;
                condition3.signal();
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                lock.unlock();
            }
        }

        public void printC() {
            lock.lock();
            try {
                while (num != 2) {
                    condition3.await();
                }
                System.out.println(Thread.currentThread().getName() + " C");
                num = 0;
                condition1.signal();
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                lock.unlock();
            }
        }

    }

AtomicInteger

    private static void testPrintABC4() {
        new PrintABC4(0).start();
        new PrintABC4(1).start();
        new PrintABC4(2).start();
    }

    static class PrintABC4 extends Thread {
        private final int flag;
        private static AtomicInteger atomicInteger = new AtomicInteger(0);

        public PrintABC4(int flag) {
            this.flag = flag;
        }

        @Override
        public void run() {
            for (int i = 0; i < 2; i++) {
                synchronized (atomicInteger) {
                    while (atomicInteger.get() % 3 != flag) {
                        try {
                            atomicInteger.wait();
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                        }
                    }
                    System.out.println(Thread.currentThread().getName() + " " + (char) (flag + 65));
                    atomicInteger.getAndIncrement();
                    atomicInteger.notifyAll();
                }
            }
        }
    }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
为了实现三个线程循环打印ABC,可以使用Synchronized同步方法和Object的wait()和notify()方法。首先,创建三个线程A、B、C,并设置它们的打印次数为10。然后,通过使用三个对象锁a、b、c来控制线程的执行顺序。A线程首先获得c对象锁,打印A后释放c对象锁,并通过notify()方法唤醒B线程。B线程等待a对象锁,获取到a对象锁后打印B,并释放a对象锁,然后通过notify()方法唤醒C线程。C线程等待b对象锁,获取到b对象锁后打印C,并释放b对象锁,并通过notify()方法唤醒A线程。这样就实现了三个线程循环打印ABC的需求。 以下是一个示例代码: ```java class PrintThread implements Runnable { private static final Object a = new Object(); private static final Object b = new Object(); private static final Object c = new Object(); private String name; public PrintThread(String name) { this.name = name; } @Override public void run() { for (int i = 0; i < 10; i++) { synchronized (name) { try { switch (name) { case "A": synchronized (c) { System.out.print("A"); c.notify(); } name.wait(); break; case "B": synchronized (a) { System.out.print("B"); a.notify(); } name.wait(); break; case "C": synchronized (b) { System.out.print("C"); b.notify(); } name.wait(); break; } } catch (InterruptedException e) { e.printStackTrace(); } } } } } public class Main { public static void main(String[] args) { Thread threadA = new Thread(new PrintThread("A")); Thread threadB = new Thread(new PrintThread("B")); Thread threadC = new Thread(new PrintThread("C")); threadA.start(); threadB.start(); threadC.start(); } } ``` 通过以上代码,三个线程将按照ABCABCABC的顺序循环打印10次。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [多线程交替打印ABC的多种实现方法](https://blog.csdn.net/xiaokang123456kao/article/details/77331878)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [三个线程轮流打印ABC](https://blog.csdn.net/yu1336199790/article/details/118725454)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值