Callable原理分析

本文深入分析了Java中实现Callable接口来创建带返回值的多线程方式。通过实例展示了如何使用Future对象获取线程执行结果,并探讨了内部原理,包括ExecutorService的submit方法、FutureTask的实现以及get方法的等待机制。最后,总结了带有返回值的异步线程执行的基本理解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

今天我们来分析实现多线程的一种方式,实现Callable接口。这种方式有种特殊的地方,就是可以拿到线程返回值。具体怎么实现的呢?我们来研究下。

栗子

我们先举个简单的栗子来看下Callable接口吧。
要首先明白,线程池提交实现Callable接口的线程后会返回一个Future对象,这个对象里包含程序的运行结果。

public class CallableTest {
   
    public static void main(String[] args) throws ExecutionException, InterruptedException,TimeoutException{
   
        //创建一个线程池
        ExecutorService executor = Executors.newCachedThreadPool();
        Future<String> future = executor.submit(()-> {
   
                //System.out.println("CallableTest");
                TimeUnit.SECONDS.sleep(5);
                return "CallableTest";
        });
        System.out.println(future.get());
    }
}

可以看到我们可以通过future.get()拿到结果"CallableTest"。
我们也可以设置指定时间后拿到结果,如指定6s后拿到结果。

System.out.println(future.get(4,TimeUnit.SECONDS));

可以看到也拿到了返回结果,如果我们设置4s拿到结果,小于程序运行时间5s,可以看到它抛出了超时异常。java.util.concurrent.TimeoutException。

原理

是不是很神奇?

我们来研究下Callable接口获取返回值的原理。

我们先来看看ExecutorService的submit方法,它接受一个Callable对象,返回一个Future对象。

<T> Future<T> submit(Callable<T> task);

及它的实现。AbstractExecutorService的submit方法。

    public <T
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值