JUC系列之(六)实现Callable接口

实现Callable接口

创建执行线程的第三种方式,共四种

比较Runnable和Callable:

  1. Callable方法可以有返回值,并且可以抛出异常。
  2. 由于Callable的方法有返回值,需要FutureTask的支持,用于接收运算结果。FutureTask 是 Future接口的实现类。

使用

package com.atguigu.juc;

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

public class TestCallable {
    public static void main(String[] args) {
        ThreadDemoA threadDemoA = new ThreadDemoA();

        // 由于Callable的方法有返回值,需要FutureTask的支持,用于接收运算结果。FutureTask 是 Future接口的实现类
        FutureTask<Integer> integerFutureTask = new FutureTask<Integer>(threadDemoA);
        new Thread(integerFutureTask).start();

        try {
            // FutureTask具有闭锁特性,等待线程执行完后再获取结果
            Integer integer = integerFutureTask.get();
            System.out.println(integer);
        } catch (InterruptedException e) {
            e.printStackTrace();
        } catch (ExecutionException e) {
            e.printStackTrace();
        }
    }
}

class ThreadDemoA implements Callable<Integer> {

    // 有返回值,并且可以抛出异常
    @Override
    public Integer call() throws Exception {
        int sum = 0;

        for (int i = 0; i < 100; i++) {
            sum += i;
        }
        return sum;
    }
}
posted @   刘二水  阅读(14)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示