Active Object pattern

简介:

之所以叫, 主动对象, 区别于被动对象, 只能被动被别人调用的对象, 而主动对象内部有线程可以自行调用自己的方法.

 

Active Object是一种高级模式, 概念上和RPC有些类似, 但是实现和用途不一样

Active Object首先使用了Proxy模式, 这个和RPC一样, 用户可以象访问local function一样使用

然后Active Object关键的一步是使用command模式分离invacation和execution, proxy并没有直接运行调用逻辑, 而是封装成command发送给invoker queue

Active Object主要用于异步并发, 而RPC主要用于web service

 

The Active Object Design pattern decouples method execution from method invocation, which reside in their own threads of control. 
The goal is to introduce concurrency and fault tolerance, by using asynchronous method invocation and a scheduler for handling requests.

Active Object 设计模式的本质是解耦合方法的调用 (Method invocation) 与方法的执行 (Method execution), 方法调用发生在调用者线程, 而方法的执行发生在独立于调用者线程的Active Object线程, 并且这个过程对用户透明.

 

在 Active Object 模式中,主要有以下几种类型的参与者:

  • 代理 (Proxy) :代理是Active Object所定义的对于调用者的公共接口. 运行时代理运行在调用者线程的上下文中, 负责把调用者的方法调用转换成相应的方法请求(Method Request), 并将其插入相应的Activation Queue, 最后返回给调用者Future对象
  • 方法请求(Command):方法请求定义了方法执行所需要的上下文信息, 诸如调用参数等
  • Activation Queue:负责存储所有由代理创建的, 等待执行的方法请求. 从运行时来看, Activation Queue会被包括调用者线程及其Active Object线程并发存取访问, 所以Activation Queue实现应当是线程安全的
  • 调度者(Scheduler):调度者运行在Active Object线程中, 调度者来决定下一个执行的方法请求, 而调度策略可以基于很多种标准, 比如根据方法请求被插入的顺序FIFO或者LIFO, 比如根据方法请求的优先级等等
  • Implementer: Implementer是Proxy所定义的接口的事实实现
  • Future: 调用者调用Proxy所定义的方法, 获得Future对象. 调用者可以从该Future对象获得方法执行的最终结果. 在真实的实现里, Future对象会保留一个私有的空间, 用来存放Implementer方法执行的结果

 image

可以通过以下的方式从Future对象获得真实的执行结果Message:

  • 同步等待: 调用者调用Future对象的result()方法同步等待, 直到后端的Implementer相应方法执行结束, 并把结果存储到了Future对象中来, result返回, 调用者获得Message
  • 同步超时等待: 调用者调用Future对象的result(timeout)方法. 如果过了timeout时间之后, 后端的Implementer相应方法执行仍未结束, 则调用失败, 否则, 调用者线程被唤醒, result方法返回, 调用者获得Message
  • 异步查询: 调用者可以通过调用Future对象定义的查询方法, 查看真实的结果是否准备好了, 如果准备好了, 调用result方法, 直接获得Message
本文章摘自博客园,原文发布日期: 2013-11-18
目录
相关文章
|
6月前
|
设计模式 Java API
【设计模式】JAVA Design Patterns——Active Object(活动对象设计模式)
【设计模式】JAVA Design Patterns——Active Object(活动对象设计模式)
|
设计模式 uml
空对象模式(Null Object Pattern)
空对象模式(Null Object Pattern)不属于GoF设计模式,但是它作为一种经常出现的模式足以被视为设计模式了。其具体定义为设计一个空对象取代NULL对象实例的检查。NULL对象不是检查控制,而是反映一个不做任何动作的关系。这样的NULL对象也可以在数据不可用的时候提供默认的行为,属于行为型设计模式。
92 0
|
设计模式 Java 数据库
对象池模式(Object Pool Pattern)
对象池模式(Object Pool Pattern),是创建型设计模式的一种,将对象预先创建并初始化后放入对象池中,对象提供者就能利用已有的对象来处理请求,减少频繁创建对象所占用的内存空间和初始化时间。
86 0
|
Java 数据库 设计模式
Java Transfer Object Pattern(传输对象模式)
传输对象模式(Transfer Object Pattern)用于从客户端向服务器一次性传递带有多个属性的数据。传输对象也被称为数值对象。传输对象是一个具有 getter/setter 方法的简单的 POJO 类,它是可序列化的,所以它可以通过网络传输。
1213 0
|
Java 数据库 存储
Java Data Access Object Pattern(数据访问对象模式)
数据访问对象模式(Data Access Object Pattern)或 DAO 模式用于把低级的数据访问 API 或操作从高级的业务服务中分离出来。以下是数据访问对象模式的参与者。
934 0
|
Java
Java Null Object Pattern(空对象模式)
在空对象模式(Null Object Pattern)中,一个空对象取代 NULL 对象实例的检查。Null 对象不是检查空值,而是反应一个不做任何动作的关系。
952 0