java并发编程:主线程等待子线程结束 CountDownLatch

本文介绍了如何在Java中使用ExecutorService创建线程池处理文件,并通过CountDownLatch实现主线程等待所有子线程完成后再继续执行。线程池执行多个任务,每个任务读取并解析文件,最后主线程调用shutdown方法并使用awaitTermination进行等待。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1) 主线程等待线程池

void shutdown()
启动一次顺序关闭,执行以前提交的任务,但不接受新任务。如果已经关闭,则调用没有其他作用。
void awaitTermination()
等待线程终止。

ExecutorService pool = Executors.newFixedThreadPool(20);
if(file.exists()&&file.isDirectory()){
File[] listFiles = file.listFiles();
for(File fileTmp:listFiles){
pool.execute(new Runnable() {
@Override
public void run() {
logger.info("file==================" + fileTmp.getName());
bService.parseBill(fileTmp);
bService.parseReport(fileTmp);
}
});
}
}
pool.shutdown();
while(! pool.awaitTermination(5, TimeUnit.SECONDS)); 

1) 主线程等待多个线程。线程之间同步。CountDownLatch

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值