线程池shutdown

本文介绍了一种利用Java中的线程池技术实现主线程等待所有子线程完成的方法。通过创建固定大小的线程池,并使用ExecutorService接口的isTerminated()方法来检查所有线程是否已结束,实现了优雅地等待所有子线程完成后再退出。
摘要由CSDN通过智能技术生成
写一个程序要求主线程等待子线程运行结束后退出,且子线程同时运行。

思路共享一个计数标志位,每个线程结束后都去更新这个计数标志位,主线程判断该计数标志位是否所有的线程都已经工作完成,但是为了不去浪费过多的CPU,主线程需要进行Thread.sleep(),但是Thread.sleep()也会倒是效率的下降,所以这样的方法并不完美。

查资料,发现java.util.concurrent包中有个名为Executors的类,可以创建线程池,于是仔细研究了一下,发现使用这个类构造一个线程池,可以很简单的解决这个问题。

package base;

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

public class Main
{
private static final int NTHREDS = 10;

public static void main(String[] args)
{
ExecutorService executor = Executors.newFixedThreadPool(NTHREDS);
for (int i = 0; i < NTHREDS; i++)
{
Runnable worker = new MyRunnable();
executor.execute(worker);
}
executor.shutdown();
while (!executor.isTerminated())
{
}
System.out.println("Finished all threads");
}

}



package base;

public class MyRunnable implements Runnable
{
public void run()
{
System.out.println(Thread.currentThread().getName());
}
}




通过不断运行ExecutorService.isTerminated()方法检测全部的线程是否都已经运行结束,ExecutorService.shutdown()将使之前通过Executor.execute()提交的任务运行结束后关闭线程池。ExecutorService还提供了一个与ExecutorService.shutdown()对应的方法名为ExecutorService.shutdownNow()该方法试图将结束已经提交的任务并结束线程池(只有调用了interrupt才起作用,亦即任务体run的代码中有sleep())。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值