CountdownLatch 和 CycliBarriar 有什么区别?

网站建设4年前发布
38 0 0

20230306014558912180a4466030ee672069515562908bfb1ccb276, 一位工作5年的小伙伴面试的时候,被问到这样一个问题,说,CountdownLatch 和 CycliBarriar 有什么区别?这个对于很多人都会比较陌生,但是接触过并发编程的小伙伴来说还是比较简单的。,今天呢,我给大家分享一下我对这个问题的理解。,2023030601445456c544c98967ec163650386b3ee662091f2822499,先来看CountDownLatch,它是一个组合词。CountDown 的意思是 倒计时,Latch 的意思是 门闩 ,也被翻译成发令枪。在JDK 注释中是这样的:,翻译过来就是说,让一个或多个线程持续等待,直到其他多线程执行的一组操作全部完成以后,这些等待的线程才会继续执行。,就好比是,有多位选手参加一场百米赛跑,裁判员需要等待全部选手就绪,并且在同一起跑线上。然后,裁判会发出号令:“各就位,预备跑”,随着发令枪响,所有选手才能全部起跑。在这个场景中,各位参赛选手就是线程,而裁判就是CountDownLatch。,我们在实际开发中,有以下两个使用场景可以用CountDownLatch来实现:,2023030601445416860ff55b8c7772b73597f9a8340fa776ece5923,(1)让单个线程等待多个线程的场景。,比如,一个服务需要从多个远程接口获取数据,我们可以创建多个线程来分别调用远程接口,等待所有远程接口都获得返回数据之后,主服务线程再往下继续执行。像并发计算,结果汇总等等。,(2)让多个线程等待的场景。,比如,模拟秒杀场景,让一组线程同时等待,同时恢复执行,实现最大程度的并行性。,2023030601445457187fc070e51652c89285b139937e6f9fc151581,需要注意的是,当高并发请求时,Countdownlatch的await方法有可能会引起死锁。,如果线程池中线程的数量较少,在高并发时会出现多个请求占用了全部的线程,但是每个请求又需要await()其他线程,被等待的线程拿不到线程资源无法执行,导致多个请求同时进入线程阻塞,最后形成死锁。,当然,我们可以使用自定义线程池来扩大线程数量,并且建立线程池拒绝机制来解决死锁问题。,20230306014454163b9cf841e53f6ddf60790804fb1e9a0a0ee3948,再来看 CyclicBarrier [ˈsaɪklɪk] [ˈbæriə],它也是一个组合词。其中Cyclic 的意思是 循环 ,Barrier 的意思是 屏障 ,又被翻译成栅栏。在JDK 注释中是这样描述的:,20230306014558590eae0778797732892406c7a8e81e445c3ca0519,翻译过来总结为以下三点:,20230306014456789853e03c42d9a9903508e9debd73277a6eb1832,从字面上理解的话,它的功能和CountdownLatch非常类似,也是等待所有参加比赛的选手全部就绪以后,才能开始起跑。它是另外一种多线程并发控制工具,和CountdownLatch不同的是,CyclicBarrier可以重复使用。,我们在实际开发中,CyclicBarrier可以用于多线程计算数据,最后合并计算结果的应用场景。,比如,需要计算N组人一年的平均工资,每组需要多个线程并行计算,计算完一组,再开始下一组,这样就需要多轮并行计算。这个场景下,CyclicBarrier 比 CountDownLatch 更适合。,202303060145598875ceb2846e726113c7675ad3dfe73ef89ca1167,最后,总结一下CountDownLatch和CyclicBarrier的区别,从以下四个方面来分析:,好了,以上就是我对CountdownLatch 和 CycliBarriar的理解。

© 版权声明

相关文章