《Java并发编程的艺术》读书笔记—— Executor框架

          Executor框架

     Executor是一个将任务与低层线程隔离的线程框架,通过把任务交给Executor框架,Executor把任务分配给线程池,线程池会根据操作系统创建内核线程,这样就可以把任务的提交和执行分离,达到程序更可控的效果
    《Java并发编程的艺术》读书笔记—— Executor框架 
      接口Executor是Executor的核心,用于将任务的提交和执行分离,而Executor还提供其他的类,比如说ExecutorService接口以及实现了ExecutorService接口和ThreadPoolExecutor和ScheduleThreadPoolExecutor,这两个类可以提交并执行Runnable、Callable<V>、Future<V>、FutureTask<V>的任务,FutrueTask可以使用get方法获取任务执行的结果,还可以使用cancel方法来取消任务。
     FutureTask是Java一种新的线程方案,通过FutureTask可以创建有返回的线程,比如下面这个例子就是使用FutureTask来创建一个返回计算加法结果的线程
package study.future;


import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future;
import java.util.concurrent.FutureTask;


public class FutureTaskTest {
public static void main(String[] args) {
FutureTask<Integer> f = new FutureTask<Integer>(new Callable<Integer>() {


@Override
public Integer call() throws Exception {
Thread.sleep(3 * 1000);
int result = 1 + 2;
return result;
}
});
f.run();
try {
System.out.println(f.get());
} catch (InterruptedException | ExecutionException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}

运行这个程序三秒会将会打印出结果3