博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Callable 获取线程返回值
阅读量:7110 次
发布时间:2019-06-28

本文共 2354 字,大约阅读时间需要 7 分钟。

allable与 Future 两功能是Java在兴许版本号中为了适应多并法才增加的,Callable是类似于Runnable的接口,实现Callable接口的类和实现Runnable的类都是可被其它线程运行的任务。

Callable的接口定义例如以下;

public interface Callable<V> { 

      V   call()   throws Exception; 

Callable和Runnable的差别例如以下:

I    Callable定义的方法是call,而Runnable定义的方法是run。

II   Callable的call方法能够有返回值,而Runnable的run方法不能有返回值。

III  Callable的call方法可抛出异常,而Runnable的run方法不能抛出异常。

 

Future 介绍

Future表示异步计算的结果,它提供了检查计算是否完毕的方法,以等待计算的完毕,并检索计算的结果。

Future的cancel方法能够取消任务的执行。它有一布尔參数,參数为 true 表示马上中断任务的执行。參数为 false 表示同意正在执行的任务执行完毕。Future的 get 方法等待计算完毕。获取计算结果

import java.util.concurrent.Callable;

import java.util.concurrent.ExecutorService;

import java.util.concurrent.Executors;

import java.util.concurrent.Future;

/**

 * Callable 和 Future接口

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

 * Callable和Runnable有几点不同:

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

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

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

 * (4)执行Callable任务可拿到一个Future对象。

 * Future 表示异步计算的结果。它提供了检查计算是否完毕的方法。以等待计算的完毕,并检索计算的结果。

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

 */

public class CallableAndFuture {

    public static class  MyCallable  implements Callable{

          private int flag = 0; 

          public MyCallable(int flag){

                  this.flag = flag;

          }

          public String call() throws Exception{

              if (this.flag == 0){

  

                      return "flag = 0";

            } 

            if (this.flag == 1){   

                try {

                    while (true) {

                            System.out.println("looping.");

                            Thread.sleep(2000);

                    }

                } catch (InterruptedException e) {

                              System.out.println("Interrupted");

                }

                return "false";

            } else {   

                       throw new Exception("Bad flag value!");

            }

        }

    }

    public static void main(String[] args) {

       // 定义3个Callable类型的任务

        MyCallable task1 = new MyCallable(0);

        MyCallable task2 = new MyCallable(1);

        MyCallable task3 = new MyCallable(2);

        

       // 创建一个运行任务的服务

        ExecutorService es = Executors.newFixedThreadPool(3);

        try {

           // 提交并运行任务,任务启动时返回了一个Future对象。

            // 假设想得到任务运行的结果或者是异常可对这个Future对象进行操作

            Future future1 = es.submit(task1);

           // 获得第一个任务的结果,假设调用get方法,当前线程会等待任务运行完成后才往下运行

            System.out.println("task1: " + future1.get());

            

            Future future2 = es.submit(task2);

           // 等待5秒后,再停止第二个任务。由于第二个任务进行的是无限循环

            Thread.sleep(5000);

            System.out.println("task2 cancel: " + future2.cancel(true));

            

           // 获取第三个任务的输出。由于运行第三个任务会引起异常

            // 所以以下的语句将引起异常的抛出

            Future future3 = es.submit(task3);

            System.out.println("task3: " + future3.get());

        } catch (Exception e){

            System.out.println(e.toString());

        }

       // 停止任务运行服务

        es.shutdownNow();

    }

}

转载地址:http://avlhl.baihongyu.com/

你可能感兴趣的文章
我的友情链接
查看>>
Why and How to Convert a VMware Virtual IDE disk to SCSI
查看>>
linux系统下ps -aux和ps -ef命令参数的作用及区别详解
查看>>
制作Nginx控制脚本实现:service nginx restart|reload|stop|st
查看>>
MySQL 体系结构以及各种文件类型学习汇总
查看>>
服务器维护常用命令
查看>>
解决squid缓存错误页面的办法
查看>>
Zabbix 安装报错
查看>>
Java+Netty、Vue+Element-UI实现的即时通信应用 leo-im
查看>>
ListView divider margin
查看>>
我的友情链接
查看>>
Python字符遍历的艺术
查看>>
《 软件性能测试与LoadRunner实战教程》喜马拉雅有声图书上线
查看>>
WIN7系统下tomcat 6 环境变量配置
查看>>
$(document).on和$('#idname').on区别
查看>>
Docker命令详解
查看>>
一直下雨,一周了。
查看>>
帮你深入理解OAuth2.0协议
查看>>
我的友情链接
查看>>
7.20_计算机基础知识
查看>>