使用场景:
多个线程相互等待,直到都满足条件之后,才能执行后续的操作。CyclicBarrier描述的是各个线程之间相互等待的关系。
使用步骤:
- 正常实例化:CyclicBarrier sCyclicBarrier=new CyclicBarrier(3);
- 带runnable的实例化,打破屏障时,优先执行Runnable:CyclicBarrier sCyclicBarrier=new CyclicBarrier(3,new Runnable(){//todo});
- await线程:sCyclicBarrier.await();
- 当wait线程数量为,count值时。唤醒所有等待线程。
原理:这里直接用源码解释(后续补充)
- 锁用的是ReentrantLock重入锁。ReentrantLock lock = new ReentrantLock()
- 获取该锁的condition实例。Condition trip = lock.newCondition()
- wait线程,用的是Condition.await
- signal线程,用的是Condition.signalAll
- 两个构造函数,初始化parties值,count值,以及Runnable(唤醒时优先执行runnable)
- count值是用来计算线程数的。每有一个线程执行了await方法,--count。直到count==0
- await方法,包含了是否超时,以及超时时间
- dowait是线程wait的主要逻辑代码。当count==0时执行唤醒操作。不为0时,进入for循环,执行Condition.await。
- dowait中的for循环是为了超时操作的逻辑。
- 正常跳出for循环是通过dowait方法中的(nextGeneration()重新实例化了gennaration)
- breakBarrier() 打破屏障,唤醒所有wait线程
- nextGeneration() 更新状态,唤醒所有wait线程
- reset()重置状态。里面调用了breakBarrier()和nextGeneration()