您的位置:首页 > 编程语言 > Java开发

java ExecutorService 线程池

2014-03-28 10:40 447 查看
读别人源代码的时候遇到了ExecutorService线程池的代码,不清楚。然后在网上查了一遍,大概懂了。

故名思意,用于存放线程的池子。

创建这个池子,有三种。

ExecutorService executorService = Executors.newCachedThreadPool();
 ExecutorService executorService = Executors.newFixedThreadPool(3);
 ExecutorService executorService = Executors.newSingleThreadExecutor();


ExecutorService实际上是一个线程池的管理工具,对于池子里面的线程有下面一些常用的方法。

executorService.isShutdown(); //判断这个池子是否已经关闭
		executorService.shutdown(); //等到池子里面的线程都完成了,再关闭
		executorService.shutdownNow(); //直接关闭,也终止池子里面未完成的线程任务
		executorService.execute(new Runnable() { //将新建的runnable对象放到池子里面,然后执行调用start()方法

			@Override
			public void run() {
				// TODO Auto-generated method stub

}
});
executorService.submit(new Runnable() { //将新建的runnable对象放到池子里面,然后执行调用start()方法。不同的时候有返回值,通过返回值可以得到线程的执行结果。
@Override
public void run() {
	// TODO Auto-generated method stub

			}
		});
		executorService.submit(new TaskWithResult(2));
		
	}
	class TaskWithResult implements Callable<String> {
        private int id;

        public TaskWithResult(int id) {
                this.id = id;
        }

	@Override
	public String call() throws Exception {
		// TODO Auto-generated method stub
		return null;
	} 
	}


从Future里获取操作结果的时候,可能会阻塞线程。没做过验证
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: