栅栏(CyclicBarrier)源码

成员:lock,trip(是lock的condition),parties,barrierCommand,generation,count
1、generation是为了标示这一次的栅栏是否被破坏。
2、parties就是构造函数时传入的参数,表示在trip之前需要执行的线程数。count被parties初始化,是一个变量,dowait时会减一,直至等于0的时候,触发nextGeneration(),里面执行了trip.signalAll(),count=parties,generation=new Generation()
3、barrierCommand在count减为0(tripped)的时候触发
所含方法:
getParties(),await(),await(long,TimeUnit),isBroken(),reset(),getNumberWaiting()
所有方法都是同步的
 
大体:通过lock来维护count变量,每次一个线程进入dowait方法,需要获取lock,对count减一,如果count剩余大于0,trip.await()。

猜你喜欢

转载自xussen.iteye.com/blog/2007385
今日推荐