java进阶之并发编程二之Concurrent同步辅助类CountDownLatch锁存器和CyclicBarrier使用

往期篇幅:

<<java进阶之并发编程一ReentrantLock同步锁的学习和syncthronized的区别>>

<<java进阶之并发编程一ReentrantLock的实际应用和线程中断EXAMPLE>>

 

引言:伴随JDK1.5的新增java.util.concurrent,java并发编程也迎来了革新,不像1.5之前只有syncthronized和Object(wait,notify)较为低效的同步方式,为了满足业务的需求,引入了许多同步辅助类,本文主要介绍CountDownLatch和CyclicBarrier的使用;

来一波概念:

CountDownLatch是java.util.concurrent中的一个class,该类的作用是充当于线程同步的一个辅助作用,在完成一组正在其他线程的操作完成之前,允许一个或多个线程进行等待。

应用场景:1,让主线程等待多个子线程完成时再进行,2,让一个子线程等待另一个子线程完成时进行......

一:CountDownLatch主要API:

CountDownLatch(int count); 初始化CountDownLatch的数量

await()在CountDownLatch为0之前一直阻塞。

await(long timeout,TimeUnit unit)CountDownLatch为0之前或超出时间前一直阻塞。

countDown()递减count的计数器,当count为0时递减依然为0。

getCount()获取当前count。

demo1:运行所有子线程,子线程全部运行完毕再运行主线程

 

demo2:将一个问题切分成多段,让每个run执行相应的分段,可提高业务处理速度。

demo3:有这么三个线程A,B,C 线程A执行完再执行B在执行C,用CountDownLatch实现

 

二:java.util.concurrent.CyclicBarrier

CyclicBarrier是一个同步辅助类,它允许多个线程在完成某个操作时都相互等待不继续执行,直到多个线程都完成才继续向后执行,

CyclicBarrier在释放等待线程后可以重用,因此也称为循环CyclicBarrier;

CyclicBarrier 主要API:

CyclicBarrier(int parties); 初始化需要相互等待的参与者;

int getParties();返回总共参与者;

await()在所有参与者调用await()之前将一直进入等待休眠状态,直到最后一个参与者到达则进行唤醒,或者其他某个线程中断;

getNumberWaiting(0返回正在等待的参与者;

reset();将屏障重置为初始状态,在所有参与者处于等待中则将他们返回并抛出异常

demo1:

结尾:好了,同步辅助类CountDownLatch和CyclicBarrier的介绍就到了,加紧练习吧!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值