读别人源代码的时候遇到了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里获取操作结果的时候,可能会阻塞线程。没做过验证