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

          Executor框架

     Executor是一个将任务与低层线程隔离的线程框架,通过把任务交给Executor框架,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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值