java主动对象模式_ACE主动对象模式

ACE主动对象模式

ACE主动对象模式解决的核心问题是,异步调用及线程context的切换。ACE主动对象的实现侧重于类代码段的并发访问,这种访问模式仅适合短小的处理流程,比如socket的accept请求,或者webservice调用。如果代码段处理响应速度大于请求到达速度,异步访问队列将很快被访问请求填充满,带来后续请求无法及时响应的问题。

ACE主动对象模式实现至少涉及3个类模块:

1:提供多线程池ACE_Task_Base或者ACE_Task或者ACE_Thread_Manager

2:提供请求排队的ACE_Activation_Queue,其内部维护了ACE_Message_Queue的message_block消息指针队列

3:提供了ACE_Activation_Queue队列操作实例的ACE_Method_Request,ACE_Method_Request是command模式,最低消耗仅为实现其内部的call方法。

ACE主动对象实现需要依赖以上3个模块,至少构建2个类

1:分发器,负责将请求参数排队,并提供数个执行线程。

2:分发对象。请求队列的排队实例。

看一下主动对象模式实现,以下为最精简代码:

1 //

2 //分发器定义

3 class CActivateDispatch: public ACE_Task

4 {5 public:6 virtual int open (void *args = 0) ;7 virtual int svc(void) ;8 voidpush();9 private:10 ACE_Activation_Queue cmdQueue; //命令队列

11 };12 //

13 //分发对象定义

14 class CActivateObject: publicACE_Method_Request15 {16 public:17 CActivateObject(CActivateDispatch *pDispatch) ;18 public:19 intcall() ;20 private:21 CActivateDispatch*m_pDispatch ;22 };23 //

24 //分发器实现

25 int CActivateDispatch::open (void *args)26 {27 //创建数个线程

28 return activate (THR_NEW_LWP|THR_JOINABLE, ACE_OS::num_processors() + 2);29 }30 voidCActivateDispatch::push()31 {32 //生成命令对象,插入到命令队列中

33 if(cmdQueue.is_full())34 ACE_DEBUG((LM_WARNING,"[%D(%t)] queue full , put away the object\n"));35 else

36 cmdQueue.enqueue(new CActivateObject(this));37 }38 intCActivateDispatch::svc ( )39 {40 while(true)41 {42 //遍历命令队列,执行命令

43 auto_ptr mo(this->cmdQueue.dequeue ());44 if (mo->call () == -1)45 break;46 }47 return 0;48 }49 voidCActivateDispatch::call()50 {51 //do something,执行环境已切换到线程上下文

52 }53 //

54 //分发对象实现

55 CActivateObject::CActivateObject(CActivateDispatch *pDispatch)56 {57 //分发对象构造函数

58 this->m_pDispatch =pDispatch;59 }60 intCActivateObject::call()61 {62 //执行环境已切换到线程上下文

63 if(m_pOB ==NULL )64 return -1;65 m_pDispatch->call();66 return 0;67 }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
课程目录 1001_RocketMQ_简介[免费观看]17:13 2002_RocketMQ_核心概念详解[免费观看]36:44 3003_RocketMQ_集群构建模型详解(一)27:47 4004_RocketMQ_集群构建模型详解(二)23:36 5005_RocketMQ_双主模式集群环境搭建39:05 6006_RocketMQ_控制台使用讲解10:41) 7007_RocketMQ_Broker配置文件详解20:38 8008_RocketMQ_helloworld示例讲解34:29 9009_RocketMQ_整体架构概述详解15:36 10010_RocketMQ_Producer_API详解24:49 11011_RocketMQ_Producer_顺序消费机制详解24:37 12012_RocketMQ_Producer_事务消息机制详解38:15 13013_RocketMQ_Consumer_Push和Pull模式及使用详解28:21 14014_RocketMQ_Consumer_配置参数详解06:45 15015_RocketMQ_Consumer_重试策略详解33:08 16016_RocketMQ_Consumer_幂等去重策略详解33:48 17017_RocketMQ_消息模式及使用讲解14:12 18018_RocketMQ_双主双从集群环境搭建与使用详解40:30 19019_RocketMQ_FilterServer机制及使用详解35:31 20020_RocketMQ_管理员命令16:37 JAVA-ACE-架构师系列视频课程- RocketMQ(下)订单实战视频课程 适用人群: 高级java工程师、java架构师 共23课时共9小时33分钟更新时间:2017-04-05 课程目标 RocketMQ(下)订单实战主要讲解rmq的分布式实战项目,围绕着订单模块等进行讲解,实现补偿等 课程目录 101_rocketmq_实战项目介绍[免费观看]22:54 202_rocketMQ实战项目设计(一)26:36 303_rocketMQ实战项目设计(二)18:39 404_rocketMQ实战-环境搭建(一)27:03 505_rocketMQ实战-环境搭建(二)28:24 606_rocketMQ实战-生产者与spring结合30:20 707_rocketMQ实战-消费者与spring结合25:47 808_rocketMQ实战-数据库模型设计28:18 909_rocketMQ实战-数据库DAO代码生成27:26 1010_rocketMQ实战-远程RPC接口设计与实现(一)29:29 1111_rocketMQ实战-远程RPC接口设计与实现(二)24:03 1212_rocketMQ实战-远程RPC接口设计与实现(三)16:44 1313_rocketMQ实战-下单流程(一)21:57 1414_rocketMQ实战-下单流程(二)22:51 1515_rocketMQ实战-下单流程(三)33:20 1616_rocketMQ实战-下单流程(四)27:47 1717_rocketMQ实战-下单流程(五)23:25 1818_rocketMQ实战-下单流程(六)17:48 1919_rocketMQ实战-下单流程(七)26:56 2020_rocketMQ实战-下单流程(八)-商品库存25:43 2121_rocketMQ实战-下单流程(九)-商品库存28:47 2222_rocketMQ实战-下单流程(十)-支付模块11:11 2323_rocketMQ实战-整体联调27:44

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值