java ExecutorService 线程池 – zidan

读别人源代码的时候遇到了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()方法@Overridepublic void run() {// TODO Auto-generated method stub}});executorService.submit(new Runnable() { //将新建的runnable对象放到池子里面,然后执行调用start()方法。不同的时候有返回值,通过返回值可以得到线程的执行结果。@Overridepublic 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;        }@Overridepublic String call() throws Exception {// TODO Auto-generated method stubreturn null;} }

从Future里获取操作结果的时候,可能会阻塞线程。没做过验证

会得到最大的满足,因为它填补了你的空虚。

java ExecutorService 线程池 – zidan

相关文章:

你感兴趣的文章:

标签云: