欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

java多线程编程之Callable实现多线程

程序员文章站 2022-03-08 22:37:22
...

Runnable接口实现多线程有一个缺点就是执行完毕后无法获取一个返回值,从jdk1.5之后提出一个新的线程实现接口:java.util.concurrent.Callable接口。
首先看这个接口的定义:

@FunctionalInterface
public interface Callable<V>{
 public V call() throws Exception;
}

java多线程编程之Callable实现多线程
Callable接口设计了泛型,这个泛型返回的就是结果的值类型。
那么Callable怎么通过Thread类的start方法来进行启动呢?看下面这个结构图:
java多线程编程之Callable实现多线程
从图中可以看出是通过futureTask,它的构造方法中可以接受Callable类的对象:
java多线程编程之Callable实现多线程
Callable实现多线程示例:

class MyThread4 implements Callable<String>{
    @Override
    public String call() throws Exception {
        for(int x=0;x<10;x++){
            System.out.println("********线程执行,x="+x);
        }
        return "线程执行完毕";
    }
}

public class Callabledemo {
    public static void main(String[] args) throws Exception {
        FutureTask<String>  task = new FutureTask<>(new MyThread4());
        new Thread(task).start();
        System.out.println("【线程返回数据】"+task.get());
    }
}

Callable实现多线程实质上和Runnable接口实现多线程相同,都是通过Thread类的构造方法传入Runnable接口对象,只不过Callable中是通过传入FutureTask对象,原因就是FutureTask类继承了Callable类,如上图类结构所示。
运行结果为:
java多线程编程之Callable实现多线程
面试题:请解释Callable和Runnable的区别:

  • Runnable是在jdk1.0的时候提出的多线程的实现接口,而Callable是在1.5的时候提出
  • java.lang.Runnable接口之中只提供了一个run方法,并且没有返回值。
  • java.util.concurrent.Callable接口中提供了Call方法,可以有返回值。
相关标签: 多线程 java