java Callable与Future的详解及实例
程序员文章站
2024-03-07 22:43:21
java callable与future
callable与 future 两功能是java在后续版本中为了适应多并法才加入的,callable是类似于run...
java callable与future
callable与 future 两功能是java在后续版本中为了适应多并法才加入的,callable是类似于runnable的接口,实现callable接口的类和实现runnable的类都是可被其他线程执行的任务。
callable的接口定义如下;
public interface callable<v> { v call() throws exception; <span id="transmark"></span> }
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(); } }
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
上一篇: php实现留言板功能
下一篇: ASP.net连接Excel的代码
推荐阅读