如何判断线程池里的线程全部执行完毕

            CountdownEvent handler = new CountdownEvent(100);
            for (int i = 0; i < 100; i++)
            {
                var j = i;
                ThreadPool.QueueUserWorkItem(_ =>
                {
                    Console.WriteLine("thread " + j);
                    Thread.Sleep(1000);   //wait 1 seconds to do something
                    handler.Signal();
                });
            }

            handler.Wait();
            Console.WriteLine("finished");


 

线程池判断所有线程是否执行完毕通常有两种方法: 1. **Future集合**:如果你使用的是`ExecutorService`并提交了`Runnable`或`Callable`任务,可以使用`Future`接口的`get()`方法。这个方法会阻塞,直到对应的线程执行完成并且结果可用。你可以将所有Future放入List中,然后遍历这个列表,当所有的`get()`都返回或抛出异常时,表示所有任务已完成。 ```java List<Future<?>> futures = executor.invokeAll(tasks); for (Future<?> future : futures) { try { future.get(); // 如果抛出InterruptedException或ExecutionException,则线程未完成 } catch (InterruptedException | ExecutionException e) { // 处理异常,如日志记录或取消剩余任务 } } ``` 2. **CountDownLatch**:如果任务的数量是已知的,可以创建一个`CountDownLatch`计数器,每个任务完成后调用其`countDown()`方法,主线程持有`CountDownLatch`实例并在所有任务完成后释放它。 ```java CountDownLatch latch = new CountDownLatch(poolSize); for (Runnable task : tasks) { pool.execute(() -> { try { task.run(); } finally { latch.countDown(); // 线程结束时减少计数器 } }); } latch.await(); // 主线程阻塞等待所有任务完成 ``` 3. **Semaphore**:如果你需要更复杂的同步策略,比如允许某个资源在一定时间内被访问多次,可以使用`Semaphore`。当所有任务完成时,信号量的许可证数量会恢复到最大值。 无论哪种方法,都需要确保正确的异常处理和线程安全,以及考虑到异常情况下的清理工作。在实际应用中,结合业务需求和线程池的具体实现选择合适的方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值