Callable创建线程的原理

我们都知道创建线程的常用两种方式是: 1.继承Thread 类,重写run方法 2.实现Runnable接口,重写run方法。

但是还有一种不常见的线程创建方式就是实现Callable接口,实现call方法。实现Callable接口会返回一个返回值。 public interface Callable返回结果并可能引发异常的任务。 实现者定义一个没有参数的单一方法,称为call 。 Callable接口类似于Runnable ,因为它们都是为其实例可能由另一个线程执行的类设计的。 然而,A Runnable不返回结果,也不能抛出被检查的异常。

那么Callable接口创建线程是如何实现的呢? 我们都知道线程启动要使用new Thread().start();其中我们可以将实现Runnable接口的类的实例化对象放在参数中,线程就可以跑起来。这时候我们就要想怎样才能将Callable和Runnable扯上关系,我们可以看下Runnable的实现类: 其中有一个叫做FutureTask的是实现类,看以下他的构造方法:

它是可以传入一个callable,FutureTask就会在运行时创建执行给定的Callable,我们的创建的线程就可以执行。

代码验证
package com.callable;

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

public class CallableTest {
          
   

    public static void main(String[] args) throws ExecutionException, InterruptedException {
          
   
        MyThread myThread = new MyThread();
        FutureTask<Integer> futureTask = new FutureTask<>(myThread);
        new Thread(futureTask,"A").start();
        Integer integer = futureTask.get();
        System.out.println(integer);


    }
}

class MyThread implements Callable<Integer>{
          
   
    @Override
    public Integer call() throws Exception {
          
   
        System.out.println("调用了call方法");
        return 1024;
    }
}

futureTask.get(): 获取返回值。 这就是Callable实现创建线程的原理,我们需要记住两个点: 1、callable时有缓存的,上面的代码当有两个线程去获取的时候只打印出一个结果。 2、获取返回值可能会造成阻塞等待,我们可以采用异步传输的方式去解决。

经验分享 程序员 微信小程序 职场和发展