标签:int res 创建线程 包装 start test 并且 执行 tca
通过Callable和Future创建线程
i. 创建Callable接口的实现类,并实现call方法,该call方法将作为线程执行体,并且有返回值,可以抛出异常。
ii. 创建Callable实现类的实例,使用FutureTask类包装Callable对象,该FuturedTask对象封装了Callable对象的call方法的返回值。
iii. 使用FutureTask对象作为Thread对象的target,创建并启动新线程。
iv. 调用FutureTask对象的get方法来获得子线程执行结束后的返回值。
1 public class TestCallable {
2 public static void main(String[] args) {
3 ThreadDemo td = new ThreadDemo();
4 //1.执行 Callable 方式,需要 FutureTask 实现类的支持,用于接收运算结果。
5 FutureTask<Integer> result = new FutureTask<>(td);
6 new Thread(result).start();
7 //2.接收线程运算后的结果
8 try {
9 Integer sum = result.get(); //FutureTask 可用于闭锁
10 System.out.println(sum);
11 System.out.println("------------------------------------");
12 } catch (InterruptedException | ExecutionException e) {
13 e.printStackTrace();
14 }
15 }
16 }
17 class ThreadDemo implements Callable<Integer>{
18 public Integer call() throws Exception {
19 int sum = 0;
20 for (int i = 0; i <= 100000; i++) {
21 sum += i;
22 }
23 return sum;
24 }
25 }
1 //创建一个线程池
2 ExecutorService pool = Executors.newFixedThreadPool(taskSize);
3 // 创建多个有返回值的任务
4 List<Future> list = new ArrayList<Future>();
5 for (int i = 0; i < taskSize; i++) {
6 Callable c = new MyCallable(i + " ");
7 // 执行任务并获取 Future 对象
8 Future f = pool.submit(c);
9 list.add(f);
10 }
11 // 关闭线程池
12 pool.shutdown();
13 // 获取所有并发任务的运行结果
14 for (Future f : list) {
15 // 从 Future 对象上获取任务的返回值,并输出到控制台
16 System.out.println("res:" + f.get().toString());
17 }
标签:int res 创建线程 包装 start test 并且 执行 tca
原文地址:https://www.cnblogs.com/HuiH/p/11910914.html