前言
countdownlatch 允许一个或多个线程等待其他线程完成操作。
应用场景
假如有一个列表的大量数据等待处理,最后全部处理完毕后返回处理结果。普通做法就是从头遍历,一个个顺序执行,这样单线程处理效率不高,我们希望使用多线程的方式处理,同时在主线程等待所有子线程处理完成。
countdownlatch的构造函数接收一个int类型的参数作为计数器,如果你想等待n个点完成,这里就传入n。
当我们调用一次countdownlatch的countdown方法时,n就会减1,countdownlatch的await会阻塞当前线程,直到n变成零。由于countdown方法可以用在任何地方,所以这里说的n个点,可以是n个线程,也可以是1个线程里的n个执行步骤。用在多个线程时,你只需要把这个countdownlatch的引用传递到线程里。
示例代码
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
public static void main(string args[]){
//初始化计数
atomicinteger count = new atomicinteger( 0 );
//创建10个线程
executorservice executorservice = executors.newfixedthreadpool( 10 );
//设置countdownlatch为10
countdownlatch countdownlatch = new countdownlatch( 10 );
for ( int i= 0 ;i< 10 ;i++){
executorservice.execute(() -> {
//每个线程累加10000次
for ( int j= 0 ;j< 10000 ;j++){
count.addandget( 1 );
}
//线程最后执行countdown
countdownlatch.countdown();
});
}
try {
//调用await方法等待
countdownlatch.await();
} catch (exception e){
e.printstacktrace();
}
system.out.println(count.tostring());
}
|
最后的执行结果就是10*10000=100000,可见所有线程都处理完了。
扩展
countdownlatch的await方法还支持超时时间的设置,当等待超时时间子线程还没执行完将不再等待继续执行主线程。
?
1
|
public boolean await( long timeout, timeunit unit)
|
熟练使用多线程处理,可以再处理大量重复性工作时发挥多线程处理的效率优势。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持快网idc。
原文链接:https://blog.csdn.net/Roy_70/article/details/80396273
相关文章
猜你喜欢
- 64M VPS建站:能否支持高流量网站运行? 2025-06-10
- 64M VPS建站:怎样选择合适的域名和SSL证书? 2025-06-10
- 64M VPS建站:怎样优化以提高网站加载速度? 2025-06-10
- 64M VPS建站:是否适合初学者操作和管理? 2025-06-10
- ASP.NET自助建站系统中的用户注册和登录功能定制方法 2025-06-10
TA的动态
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
您的支持,是我们最大的动力!
热门文章
-
将Sublime Text 2固定到Ubuntu启动器的方法
2025-05-25 90 -
2025-06-04 40
-
2025-06-05 54
-
2025-05-25 81
-
2025-05-25 24
热门评论