189 8069 5689

Java多线程Callable和Future接口有什么区别

小编这次要给大家分享的是Java多线程Callable和Future接口有什么区别,文章内容丰富,感兴趣的小伙伴可以来了解一下,希望大家阅读完这篇文章之后能够有所收获。

公司主营业务:成都做网站、成都网站设计、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联公司是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联公司推出新密免费做网站回馈大家。

Runnable是执行工作的独立任务,但是不返回任何值。如果我们希望任务完成之后有返回值,可以实现Callable接口。在JavaSE5中引入的Callable是一个具有类型参数的范型,他的类型参数方法表示为方法call()而不是run()中返回的值,并且必须使用ExecutorService.submint()方法进行调用。

代码如下

import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask;
/*
 * 一、创建执行线程的方式三:实现 Callable 接口。 相较于实现 Runnable 接口的方式,方法可以有返回值,并且可以抛出异常。
 *
 * 二、执行 Callable 方式,需要 FutureTask 实现类的支持,用于接收运算结果。 FutureTask 是 Future 接口的实现类
 */
public class TestCallable {
 
  public static void main(String[] args) {
    ThreadDemo td =new ThreadDemo();
 
    //1.执行 Callable 方式,需要 FutureTask 实现类的支持,用于接收运算结果。
    FutureTask result =new FutureTask<>(td);
 
    new Thread(result).start();
 
    //2.接收线程运算后的结果
    try {
      Integer sum = result.get(); //FutureTask 可用于 闭锁 类似于CountDownLatch的作用,在所有的线程没有执行完成之后这里是不会执行的
      System.out.println(sum);
      System.out.println("------------------------------------");
    }catch (InterruptedException | ExecutionException e) {
      e.printStackTrace();
    }
  }
}
class ThreadDemo implements Callable {
  @Override
  public Integer call() throws Exception {
    int sum = 0;
 
    for (int i = 0; i <= 100000; i++) {
      sum += i;
    }
    return sum;
  }
}

综上例子可以看到: Callable 和 Future接口的区别

(1)Callable规定的方法是call(),而Runnable规定的方法是run().

(2)Callable的任务执行后可返回值,而Runnable的任务是不能返回值的。

(3)call()方法可抛出异常,而run()方法是不能抛出异常的。

(4)运行Callable任务可拿到一个Future对象, Future表示异步计算的结果。

它提供了检查计算是否完成的方法,以等待计算的完成,并检索计算的结果。

通过Future对象可了解任务执行情况,可取消任务的执行,还可获取任务执行的结果。

Callable是类似于Runnable的接口,实现Callable接口的类和实现Runnable的类都是可被其它线程执行的任务。

看完这篇关于Java多线程Callable和Future接口有什么区别的文章,如果觉得文章内容写得不错的话,可以把它分享出去给更多人看到。


文章标题:Java多线程Callable和Future接口有什么区别
浏览路径:http://gzruizhi.cn/article/piscci.html

其他资讯