一文详解Java闭锁和栅栏的实现
题目描述 -闭锁
题目
有3个线程,线程A和线程B并行执行,线程C需要和线程A和B执行完成后才能执行,使用闭锁CountDownLatch实现
解题思路
创建一个类 :Abc Test
CountDownLatch初始化值为2
新增 A B线程,在线程里执行逻辑后,计算-1
countDownLatch.countDown()
新增C线程,等待A,B线程来完成
countDownLatch.await();
执行相关的逻辑
代码详解
AbcTest:
package cn.xiaoxuzhu.daily; import java.util.concurrent.CountDownLatch; public class AbcTest { public static void main(String[] args) { CountDownLatch countDownLatch =new CountDownLatch(2); //线程A new Thread(new Runnable() { @Override public void run() { try { Thread.sleep(2000); }catch (InterruptedException e){ e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"线程A执行结束"); countDownLatch.countDown(); } },"线程A").start(); //线程B new Thread(new Runnable() { @Override public void run() { try { Thread.sleep(1000); }catch (InterruptedException e){ e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"线程B执行结束"); countDownLatch.countDown(); } },"线程B").start(); new Thread(new Runnable() { @Override public void run() { try { countDownLatch.await(); }catch (InterruptedException e){ e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"线程C执行结束"); countDownLatch.countDown(); } },"线程C").start(); } }
题目二描述 :栅栏
题目
有3个线程,线程A和线程B并发执行,线程C需要A和B执行完成后才能执行。使用删栏CyclicBarrier实现
解题思路
栅栏类似于闭锁,它能阻塞一组线程直到某个事件发生。栅栏与闭锁的关键区别在于,所有的线程
必须同时到达栅栏的位置,才能继续执行。
创建一个类:Abc Test2
CyclicBarrier初始化值为3
新增A,B线程,在线程里执行完逻辑后,栅栏等待,符合三个线程都达到栅栏才往下执行
cyclicBarrier.wait();
新增C线程,先栅栏等待,等A,B线程到达栅栏,就一起往下执行
代码详解
package cn.xiaoxuzhu.daily; import java.util.concurrent.BrokenBarrierException; import java.util.concurrent.CyclicBarrier; /** * Description: 有3个线程。线程A和线程B并行执行,线程C需要A和B执行完成后才能执行。可以怎么实现? * * @author 小王同学 * @version 1.0 * @Description: */ public class AbcTest2 { public static void main(String[] args) { CyclicBarrier cyclicBarrier=new CyclicBarrier(3); //线程A new Thread(new Runnable() { @Override public void run() { try { Thread.sleep(2000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"线程A执行结束"); try { cyclicBarrier.await();//符合三个线程都到达栅栏才往下执行 } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } },"线程A").start(); //线程B new Thread(new Runnable() { @Override public void run() { try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"线程B执行结束"); try { cyclicBarrier.await();//符合三个线程都到达栅栏才往下执行 } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } },"线程B").start(); //线程C new Thread(new Runnable() { @Override public void run() { //等待A,B线程完成 try { cyclicBarrier.await();//符合三个线程都到达栅栏才往下执行 } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"线程C执行结束"); } },"线程C").start(); } }
到此这篇关于一文详解Java闭锁和栅栏的实现的文章就介绍到这了,更多相关Java闭锁 栅栏内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
java的各种集合为什么不安全(List、Set、Map)以及代替方案
这篇文章主要介绍了java的各种集合为什么不安全(List、Set、Map)以及代替方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-10-10SpringBoot整合MyBatis实现CRUD操作项目实践
本文主要介绍了SpringBoot整合MyBatis实现CRUD操作项目实践,如何实现数据库的CRUD创建、读取、更新、删除操作,具有一定的参考价值,感兴趣的可以了解一下2024-02-02
最新评论