当前位置:首页 > 开发 > 编程语言 > 多线程 > 正文

线程池shutdown

发表于: 2011-06-10   作者:coach   来源:转载   浏览:
摘要: 写一个程序要求主线程等待子线程运行结束后退出,且子线程同时运行。 思路共享一个计数标志位,每个线程结束后都去更新这个计数标志位,主线程判断该计数标志位是否所有的线程都已经工作完成,但是为了不去浪费过多的CPU,主线程需要进行Thread.sleep(),但是Thread.sleep()也会倒是效率的下降,所以这样的方法并不完美。 查资料,发现java.util.concurrent包中
写一个程序要求主线程等待子线程运行结束后退出,且子线程同时运行。

思路共享一个计数标志位,每个线程结束后都去更新这个计数标志位,主线程判断该计数标志位是否所有的线程都已经工作完成,但是为了不去浪费过多的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())。



线程池shutdown

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号