一、Future模式概述
二、Future序列图
三、示例代码
一、Future模式概述
Future类似于商品订单问题,当用户看上一件商品之后,下单完成在家里等待送货上门即可。更形象的一个例子就是页面发送AJAX请求,页面异步进行后台处理,用户无需一直等待结果,可以浏览其他东西。
Future的原理是:当你申请资源(计算资源或I/O资源)时,立即返回一个虚拟的资源句柄,当真正使用的时候,再将虚拟的句柄转化成真正的资源,相当于预获取。
二、Future序列图
三、代码示例
(1)FutureData类与RealData类共同实现同一个接口
package net.oschina.tkj.mulitcoding.futuremodel; /** * 数据接口,用户请求数据,并且返回用户需要真实数据 * * @author Freedom * */ public interface Data { String getRequest(String req); }
(2)FutureData类(类似一个空的包装类)
该类只有获取到真实数据之后,当用户需要数据时,才能继续执行。
package net.oschina.tkj.mulitcoding.futuremodel; /** * FutureData数据包装类,用户直接与该类进行交互 * * 用户将请求发送到该类,由该类异步的获取真实的数据 * * @author Freedom * */ public class FutureData implements Data { private RealData realData = null; private static final Object lock = new Object(); private boolean isReady = false; /** * 处理client请求的方法 * * 用户需要数据时,调用该方法拿到真实数据 */ @Override public String getRequest(String req) { synchronized (lock) { if (!isReady) { try { lock.wait(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } return realData.getRequest(req); } } /** * 用于设置包装类中的数据 * * @param data */ public void setRealData(RealData data) { synchronized (lock) { if (isReady) { return; } this.realData = data; isReady = true; // 有真实数据表示 // 唤醒获取数据的线程 lock.notify(); } } }
(3)真实数据类
package net.oschina.tkj.mulitcoding.futuremodel; import java.util.concurrent.TimeUnit; /** * 真实数据的类,与FutureData类进行交互,该类提供真实数据 * * @author Freedom * */ public class RealData implements Data { private String data; /** * 设置真实数据 */ public synchronized void setRealData() { System.out.println("获取真实数据开始...此过程很耗时..."); try { TimeUnit.SECONDS.sleep(5); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println("获取到了真实数据..."); data = "这是这真实数据"; } @Override public String getRequest(String req) { return data; } }
(4)客户端类
package net.oschina.tkj.mulitcoding.futuremodel; /** * Future模式的客户端 * * 用于获取到数据包装类对象 * * @author Freedom * */ public class FutureCli { public synchronized Data getFutureData(String req) { final FutureData data = new FutureData(); /* * 模块核心部分,开启一个线程,目的为了异步获取真实数据 */ new Thread(new Runnable() { @Override public void run() { RealData real = new RealData(); real.setRealData(); // 将获取到的真实数据设置到包装类中 data.setRealData(real); } }).start(); return data; } }
(5)主类
package net.oschina.tkj.mulitcoding.futuremodel; public class Main { public static void main(String[] args) { FutureCli cli = new FutureCli(); Data data = cli.getFutureData("用户发来的请求参数信息..."); System.out.println("获取数据的过程ing......"); // 获取到的真实数据 System.out.println(data.getRequest("请求参数....")); } }
相关推荐
【31 凭票取餐—Future模式详解】 在Java并发编程中,Future模式是一种常见的设计模式,它允许主线程在不阻塞的情况下启动一个异步任务,然后在需要时获取任务的结果。Future模式的灵感来源于现实生活中的场景,如...
Future模式核心思想是异步调用,这里具体实现代码,其思想是:网上订了一个货之后,他会立即返回下好订单给你,你可以去做其他事,不用再一直等这个货物到达,以后有时间,货物到了,你就可以拿这个订单,去取货。...
Spring Boot对Future模式的支持使得开发者可以更方便地在应用程序中实现异步处理,从而提高系统的并发性能和响应速度。在实际开发中,当遇到需要执行耗时操作或复杂计算时,我们可以利用多线程来提升效率,而Future...
老生常谈java中的Future模式 在 Java 中,Future 模式是一种常用的设计模式,用于处理并发编程中的多线程问题。在这个模式中,线程 A 需要等待线程 B 的结果,但线程 A 不需要一直等待线程 B,可以先拿到一个未来的...
灵活且超轻量级的库,用于使用 Future 模式、回调(NodeJS 风格)和异步非阻塞编程。 动机 该库的第一个目标是为 Java 8 提供模式的轻量级实现。此外,该库还提供对 Java 流水线的支持。 第二个目的是演示 Java 8 ...
在Java编程领域,NIO(New Input/Output)和Future模式是两个重要的概念,它们分别在并发处理和异步操作中发挥着关键作用。这里我们将深入探讨这两个知识点,并结合压缩包中的"nioStudy"文件来解析它们的应用。 一...
Java 中的 Future 模式允许我们提交一个异步任务并获取其结果,而无需直接管理线程。我们可以在提交任务后继续执行其他操作,稍后再通过 Future 对象获取结果。这种方式提高了程序的并发性和灵活性。 在实际应用中...
Future模式的优势在于它能够将异步的数据驱动自然地融入到顺序流程中,使得并发代码保持简洁和优雅。与回调驱动相比,Future模式避免了回调函数中可能出现的线程安全问题,同时提供了更好的顺序流程控制。回调虽然...
Future模式允许启动一个异步操作,并在后续代码中获取结果。Java的`Future`接口和`Callable`接口结合`ExecutorService`可以实现这一模式,提高程序的响应速度。 八、线程局部变量模式 线程局部变量(`ThreadLocal`)...
5. **Future模式**:Future模式是一种并发设计模式,它提供了异步操作的结果。在Java中,`java.util.concurrent.Future`接口代表一个异步计算的结果,可以检查计算是否完成,取消计算,或者获取计算结果。通常与...
- Future模式:异步执行任务并返回结果,提供了一种机制来获取异步任务的结果。 - 生产者消费者模式:管理不同线程之间的数据交换。 #### 三、单例模式详解 单例模式是一种常用的创建型设计模式,它确保一个类...
3. 同步和通信模式:探讨在多线程程序中,线程间的同步机制和通信手段,如信号量、栅栏、Future模式等。 4. 并发集合和映射的设计模式:介绍在多线程环境中,如何安全地使用集合数据结构,以及专门针对并发访问设计...
7. **future模式**:future模式用于异步计算的结果获取。Java的`Future`接口和`Callable`接口配合`ExecutorService`,可以预提交任务并在未来某个时刻获取结果。 8. **竞争条件(Race Condition)和死锁避免**:在...
Future接口是Java线程Future模式的实 现,可以来进行异步计算。 Future模式可以这样来描述:我有一个任务,提交给了Future,Future替我完成这个任务。期间我自己可以去做任何想做的事情。一段时 间之后,我就便...
**定义:**Future模式是一种允许客户端异步地获取结果的模式。它提供了一个代理对象(Future),该对象代表了某个正在进行的任务的结果。 **关键要素:** - `Future`接口:表示计算结果的未来可用性。 - `...
5. **future模式**:Future接口代表异步计算的结果,可以查询计算是否完成,获取结果,甚至取消计算。CompletableFuture提供更强大的异步编程支持。 四、Java并发工具 1. **CountDownLatch**:用于计数,当计数到达...
7. **Future模式**:异步编程模型中的一种设计模式,用户提交一个任务并获取一个Future对象,当任务完成时可以通过Future对象获取结果。 8. **责任链模式**:将多个处理步骤组织成一条链,每个处理步骤负责一部分...
6. **future模式**:`Future`接口和`Callable`接口一起使用,可以异步执行任务并获取结果。这在等待某个耗时操作完成,而不阻塞当前线程的情况下非常有用。 7. **线程间通信模式**:`wait()`、`notify()`和`...
本书共7章:第1章主要介绍并行编程的基本概念与并行计算的基础理论,第2章主要介绍并行循环的知识,第3章介绍并行任务处理,第4章阐述并行合并计算的机理,第5章介绍future模式,第6章在前文的基础上深入探讨动态...