Java多线程Callable接口

来源:互联网 发布:韩国迷你网络剧 编辑:程序博客网 时间:2024/05/18 01:53

Runnable是执行工作的独立任务,但是它不返回任何值,如果你希望任务在完成时能够返回一个值,那么可以实现Callable接口而不是Runnable接口。在Java SE5中引入的Callable是一种具有类型参数的泛型,它的类型参数表示的是从方法call()中返回的值,并且必须使用ExecutorService.submit()方法调用它。

import java.util.ArrayList;import java.util.concurrent.Callable;import java.util.concurrent.ExecutionException;import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;import java.util.concurrent.Future;public class TaskWithResult implements Callable<String> {    private int id;    public TaskWithResult(int id){        this.id = id;    }    @Override    public String call() throws Exception {        return "result of TaskWithResult" + id;    }    public static void main(String[] args) {        ExecutorService exec = Executors.newCachedThreadPool();        ArrayList<Future<String>> results = new ArrayList<Future<String>>();        for(int i = 0;i<10;i++){            results.add(exec.submit(new TaskWithResult(i)));        }        for(Future<String> fs : results){            try {                //检查Future是否已经完成                System.out.println(fs.isDone());                //获取结果                System.out.println(fs.get());            } catch (InterruptedException e) {                // TODO Auto-generated catch block                e.printStackTrace();            } catch (ExecutionException e) {                // TODO Auto-generated catch block                e.printStackTrace();            }finally {            exec.shutdown();            }        }    }}

这里写图片描述
submit()方法会产生Future对象,它用Callable返回结果的特定类型进行了参数化。你可以用isDone()方法来查询Future是否已经完成。当任务完成时,它具有一个结果,你可以调用get()方法来获取该结果。你也可以不用isDone()进行检查就直接调用get(),在这种情况下,get()将阻塞,直至结果准备就绪。

1 0