Java接口:Callable 与 Future
2012-05-31 11:16
309 查看
Callable与Future类别可以协助您完成 Future
模式 。
Callable是个介面,与Runnable类似,有个必须实作的方法,可以启动为另一个执行绪来执行,不过Callable工作完成后,可以传回结果物件,Callable介面的定义如下:
public interface Callable<V> {
V call() throws Exception;
}
例如您可以使用Callable来完成某个费时的工作,工作结束后传回结果物件,例如求质数:
PrimeCallable.java
假设现在求质数的需求是在启动PrimeCallable后的几秒之后,则我们可以搭配Future来取得Callable执行的结果,在未来的时间点取得结果,例如:
FutureDemo.java
模式 。
Callable是个介面,与Runnable类似,有个必须实作的方法,可以启动为另一个执行绪来执行,不过Callable工作完成后,可以传回结果物件,Callable介面的定义如下:
public interface Callable<V> {
V call() throws Exception;
}
例如您可以使用Callable来完成某个费时的工作,工作结束后传回结果物件,例如求质数:
PrimeCallable.java
package onlyfun.caterpillar; import java.util.ArrayList; import java.util.List; import java.util.concurrent.Callable; public class PrimeCallable implements Callable<int[]> { private int max; public PrimeCallable(int max) { this.max = max; } public int[] call() throws Exception { int[] prime = new int[max+1]; List<Integer> list = new ArrayList<Integer>(); for(int i = 2; i <= max; i++) prime[i] = 1; for(int i = 2; i*i <= max; i++) { // 这边可以改进 if(prime[i] == 1) { for(int j = 2*i; j <= max; j++) { if(j % i == 0) prime[j] = 0; } } } for(int i = 2; i < max; i++) { if(prime[i] == 1) { list.add(i); } } int[] p = new int[list.size()]; for(int i = 0; i < p.length; i++) { p[i] = list.get(i).intValue(); } return p; } }
假设现在求质数的需求是在启动PrimeCallable后的几秒之后,则我们可以搭配Future来取得Callable执行的结果,在未来的时间点取得结果,例如:
FutureDemo.java
package onlyfun.caterpillar; import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.FutureTask; public class FutureDemo { public static void main(String[] args) { Callable<int[]> primeCallable = new PrimeCallable(1000); FutureTask<int[]> primeTask = new FutureTask<int[]>(primeCallable); Thread t = new Thread(primeTask); t.start(); try { // 假设现在做其它事情 Thread.sleep(5000); // 回来看看质数找好了吗 if(primeTask.isDone()) { int[] primes = primeTask.get(); for(int prime : primes) { System.out.print(prime + " "); } System.out.println(); } } catch (InterruptedException e) { e.printStackTrace(); } catch (ExecutionException e) { e.printStackTrace(); } } }
相关文章推荐
- Java多线程研究06-带返回值的线程定义接口Callable以及Future,FutureTask的使用
- Java 多线程设置线程超时时间之 Callable接口和Future接口 线程超时控制
- 并发模式Future ,JAVA内置模块Callable接口实现 实例
- Java中利用Future和callable接口监测异步线程的理解
- Java Callable Future接口执行机制解密
- Java 多线程设置线程超时时间之 Callable接口和Future接口 超时控制
- JAVA多线程实现方式主要有三种:继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程。其中前两种方式线程执行完后都没
- Java Thread&Concurrency(7): 深入理解Callable/Future(FutureTask)接口及其实现
- java自定义任务类定时执行任务示例 callable和future接口使用方法
- JAVA多线程实现的三种方式(继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程)
- Java线程(七):Callable和Future
- 从头认识java-17.6 Callable、Future和FutureTask
- Java线程:Callable和Future
- Java并发编程:Callable、Future和FutureTask
- Java中的Runnable、Callable、Future、FutureTask的区别与示例
- Java并发编程:Callable、Future和FutureTask
- Java中的Callable和Future
- Java并发编程:Callable、Future和FutureTask
- 【Java】Callable接口与Runnable接口的区别
- Java中的Runnable、Callable、Future、FutureTask的区别与示例