Java并发之Future类和Callable类详解
来源:互联网 发布:晋明帝 司马懿 知乎 编辑:程序博客网 时间:2024/06/08 02:44
有时候在实际应用中,某些操作很耗时,但又不是不可或缺的步骤。比如用网页浏览器浏览新闻时,最重要的是显示文字内容,至于与新闻相匹配的图片就没有那么重要的,所以此时首先保证文字信息先显示,而图片信息会后显示,但又不能不显示,由于下载图片是一个耗时的操作,所以必须一开始就得下载。
Java的并发库的Future类就可以满足这个要求。Future的重要方法包括get()和cancel(),get()获取数据对象,如果数据没有加载,就会阻塞直到取到数据,而 cancel()是取消数据加载。另外一个get(timeout)操作,表示如果在timeout时间内没有取到就失败返回,而不再阻塞。
下面的Demo简单的说明了Future的使用方法:一个非常耗时的操作必须一开始启动,但又不能一直等待;其他重要的事情又必须做,等完成后,就可以做不重要的事情。
运行结果:
Java的并发库的Future类就可以满足这个要求。Future的重要方法包括get()和cancel(),get()获取数据对象,如果数据没有加载,就会阻塞直到取到数据,而 cancel()是取消数据加载。另外一个get(timeout)操作,表示如果在timeout时间内没有取到就失败返回,而不再阻塞。
下面的Demo简单的说明了Future的使用方法:一个非常耗时的操作必须一开始启动,但又不能一直等待;其他重要的事情又必须做,等完成后,就可以做不重要的事情。
- package concurrent;
- 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 TestFutureTask {
- public static void main(String[] args) throws InterruptedException,ExecutionException{
- final ExecutorService exec = Executors.newFixedThreadPool(5);
- Callable call = new Callable(){
- public String call() throws Exception{
- Thread.sleep(1000 * 5);
- return "Other less important but longtime things.";
- }
- };
- Future task = exec.submit(call);
- //重要的事情
- Thread.sleep(1000 * 3);
- System.out.println("Let's do important things.");
- //其他不重要的事情
- String obj = (String)task.get();
- System.out.println(obj);
- //关闭线程池
- exec.shutdown();
- }
- }
运行结果:
- Let's do important things.
- Other less important but longtime things.
阅读全文
0 0
- Java并发之Future类和Callable类详解
- java 并发之Callable和Future
- Java并发之Callable、Future
- 并发编程之Callable和Future接口、FutureTask类
- Java并发编程线程中:Callable、Future和FutureTask类
- Android并发编程之白话文详解Future,FutureTask和Callable
- Android并发编程之白话文详解Future,FutureTask和Callable
- Android并发编程之白话文详解Future,FutureTask和Callable
- Android并发编程之白话文详解Future,FutureTask和Callable
- Android并发编程之详解Future,FutureTask和Callable
- Java并发编程-Executor框架之Callable和Future接口
- Java并发编程之线程池、Callable和Future使用
- Java并发编程-Executor框架之Callable和Future接口
- Java并发编程之Callable,Future,FutureTask
- Java并发——Callable和Future
- Java并发编程:Callable、Future和FutureTask
- Java并发编程:Callable、Future和FutureTask
- java并发编程:Callable、Future和FutureTask
- 网易云深度学习第二课Notebook3
- 第十四天 列表生成式或列表生成器
- filter web.xml
- 医学信号数据集
- JSP指令
- Java并发之Future类和Callable类详解
- OpenJDK和JDK区别
- socket编程简单示例
- filter logincontroller
- Fragment重叠问题引发的思考
- 记2017CCPC杭州站打铁经验
- 临时备忘录
- apt-get安装linux软件简单至极------一键搞定tree、g++、samba、ssh、curl等东东
- 【设计模式】建造者模式