JAVA并发包中有三个类用于同步一批线程的行为,分别是CountDownLatch、Semaphore和CyclicBarrier。
CountDownLatch
CountDownLatch是一个计数器闭锁,主要的功能就是通过await()方法来阻塞住当前线程,然后等待计数器减少到0了,再唤起这些线程继续执行。 这个类里主要有两个方法,一个是向下减计数器的方法:countdown(),其实现的核心代码如下:
public boolean tryReleaseShared(int releases) {
// Decrement count; signal when transition to zero
for (;;) {
int c = getState();
if (c == 0)
return false;
int nextc = c-1;
if (compareAndSetState(c, nextc))
return nextc == 0;
}
}
很简单,如果取得当前的状态为0,说明这个锁已经结束,直接返回false;如果没有结束,然后去设置计数器减1,如果compareAndSetState不成功,则继续循环执行。 而其中的一直等待计数器归零的方法是await()。
通过CountDownLatch可以做几件事情:
1. 主线程控制同时启动一组线程
本文介绍了Java并发编程中重要的三个工具类:CountDownLatch、Semaphore和CyclicBarrier。CountDownLatch用于阻塞线程直到计数器归零;Semaphore作为流量阀门,限制并发线程数量,支持释放许可;CyclicBarrier则充当关卡,所有线程到达关卡后统一执行后续操作。这三个工具常用于线程同步和流量控制。
最低0.47元/天 解锁文章
2506

被折叠的 条评论
为什么被折叠?



