CountDownLatch 线程记数

开发中,有可能会遇到这样的情况,我们需要所有的线程都执行结束之后,在进行下一步操作,这个时候就可以借用CountDownLatch类进行操作,代码如下

package ice.snow.count;



import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;


/**
 * 使用CuntDownLatch类进行线程技术,保证所有的线程执行完之后,在执行下一步操作
 * @author SnowInk
 *
 */
public class Main {


public static void main(String[] args) {
// 定义线程数量
int size = 5;
// 定义countDownLatch
CountDownLatch latch = new CountDownLatch(size);
// 使用线程池进行线程处理
ExecutorService executor = Executors.newCachedThreadPool();
for (int i = 0 ; i < size ; i ++) {
final int a = i;
// 这里采用jdk8的lambda表达式进行线程的实现,也可以使用传统实现Runnable的方式进行操作,将latch作为参数传给Runnable的实现类即可
executor.execute(() -> {
System.out.println("线程-" + a + " 在执行");
try {
// 每个线程沉睡两秒
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
// 线程执行结束后,记数减一
latch.countDown();
});
}
try {
// 记数处于阻塞状态,当记数为0时可进行下一步操作,也可以使用await的重载方法,设置阻塞时间
latch.await();
}catch (Exception e) {
e.printStackTrace();
}
executor.shutdown();
System.out.println("线程全部执行结束");
}
}
阅读更多
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

不良信息举报

CountDownLatch 线程记数

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭