- 浏览: 2031792 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (651)
- ACE (35)
- BAT (9)
- C/C++ (116)
- fast-cgi (14)
- COM (27)
- python (59)
- CGI (4)
- C# (2)
- VC (84)
- DataBase (29)
- Linux (96)
- P2P (6)
- PHP (15)
- Web (6)
- Memcached (7)
- IME输入法 (11)
- 设计模式 (2)
- 搜索引擎 (1)
- 个人情感 (4)
- 笔试/面试 (3)
- 一亩三分地 (33)
- 历史 (2)
- 地理 (1)
- 人物 (3)
- 经济 (0)
- 不仅仅是笑哦 (43)
- 小故事大道理 (2)
- http://www.bjdsmyysjk120.com/ (0)
- http://www.bjdsmyy120.com/ (0)
- 它山之石可以攻玉 (15)
- 大学生你关注些什么 (28)
- 数据恢复 (1)
最新评论
-
luokaichuang:
这个规范里还是没有让我明白当浏览器上传文件时,STDIN的消息 ...
FastCGI规范 -
effort_fan:
好文章!学习了,谢谢分享!
com技术简介 -
vcell:
有错误os.walk(strPath)返回的已经是全部的文件和 ...
通过python获取目录的大小 -
feifeigd:
feifeigd 写道注意:文章中的CPP示例第二行 #inc ...
ATL入门:利用ATL编写简单的COM组件 -
feifeigd:
注意:文章中的CPP示例第二行 #include " ...
ATL入门:利用ATL编写简单的COM组件
主动对象模式用于降低方法执行和方法调用之间的耦合。该模式描述了另外一种更为透明的任务间通信方法。 传统上,所有的对象都是被动的代码段,对象中的代码是在对它发出方法调用的线程中执行的,当方法被调用时,调用线程将阻塞,直至调用结束。而主动对象却不一样。这些对象具有自己的命令执行线程,主动对象的方法将在自己的执行线程中执行,不会阻塞调用方法。 例如,设想对象"A"已在你的程序的main()函数中被实例化。当你的程序启动时,OS创建一个线程,以从main()函数开始执行。如果你调用对象A的任何方法,该线程将"流过"那个方法,并执行其中的代码。一旦执行完成,该线程返回调用该方法的点并继续它的执行。但是,如果"A"是主动对象,事情就不是这样了。在这种情况下,主线程不会被主动对象借用。相反,当"A"的方法被调用时,方法的执行发生在主动对象持有的线程中。另一种思考方法:如果调用的是被动对象的方法(常规对象),调用会阻塞(同步的);而另一方面,如果调用的是主动对象的方法,调用不会阻塞(异步的)。 由于主动对象的方法调用不会阻塞,这样就提高了系统响应速度,在网络编程中是大有用武之地的。 在这里我们将一个"Logger"(日志记录器)对象对象为例来介绍如何将一个传统对象改造为主动对象,从而提高系统响应速度。 Logger的功能是将一些系统事件的记录在存储器上以备查询,由于Logger使用慢速的I/O系统来记录发送给它的消息,因此对Logger的操作将会导致系统长时间的等待。 其功能代码简化如下:
为了实现实现记录日志操作的主动执行,我们需要用命令模式将其封装,从而使得记录日志的方法能在合适的时间和地方主动执行,封装方式如下:
这里对代码功能做一下简单的说明: ACE_Method_Object是ACE提供的命令模式借口,命令接口调用函数为int call(),在这里通过它可以把每个操作日志的调用封装为一个LogMsgCmd对象,这样,当原来需要调用LogMsg的方法的地方只要调用LogMsgActive即可生成一个LogMsgCmd对象,由于调用LogMsgActive方法,只是对命令进行了封装,并没有进行日志操作,所以该方法会立即返回。然后再新开一个线程,将LogMsgCmd对象作为参数传入,在该线程中执行LogMsgCmd对象的call方法,从而实现无阻塞调用。 然而,每次对一个LogMsg调用都开启一个新线程,无疑是对资源的一种浪费,实际上我们往往将生成的LogMsgCmd对象插入一个命令队列中,只新开一个命令执行线程依次执行命令队列中的所有命令。并且,为了实现对象的封装,命令队列和命令执行线程往往也封装到Logger对象中,代码如下所示:
在这里需要注意一下命令队列ACE_Activation_Queue对象,它是线程安全的,使用方法比较简单,这里我也不多介绍了。 主动对象的基本结构就是这样,然而,由于主动对象是异步调用的,又引出了如下两个新问题: 这两个问题将在下回给与解决。class Logger: public ACE_Task<ACE_MT_SYNCH>
{
public:
void LogMsg(const string& msg)
{
cout<<endl<<msg<<endl;
ACE_OS::sleep(2);
}
};
class LogMsgCmd: public ACE_Method_Object
{
public:
LogMsgCmd(Logger *plog,const string& msg)
{
this->log=plog;
this->msg=msg;
}
int call()
{
this->log->LogMsg(msg);
return 0;
}
private:
Logger *log;
string msg;
};
class Logger: public ACE_Task<ACE_MT_SYNCH>
{
public:
void LogMsg(const string& msg)
{
cout<<endl<<msg<<endl;
ACE_OS::sleep(2);
}
LogMsgCmd *LogMsgActive(const string& msg)
{
new LogMsgCmd(this,msg);
}
};
#include "ace/OS.h"
#include "ace/Task.h"
#include "ace/Method_Object.h"
#include "ace/Activation_Queue.h"
#include "ace/Auto_Ptr.h"
#include <string>
#include <iostream>
using namespace std;
class Logger: public ACE_Task<ACE_MT_SYNCH>
{
public:
Logger()
{
this->activate();
}
int svc();
void LogMsg(const string& msg);
void LogMsgActive (const string& msg);
private:
ACE_Activation_Queue cmdQueue; //命令队列
};
class LogMsgCmd: public ACE_Method_Object
{
public:
LogMsgCmd(Logger *plog,const string& msg)
{
this->log=plog;
this->msg=msg;
}
int call()
{
this->log->LogMsg(msg);
return 0;
}
private:
Logger *log;
string msg;
};
void Logger::LogMsg(const string& msg)
{
cout<<endl<<msg<<endl;
ACE_OS::sleep(2);
}
//以主动的方式记录日志
void Logger::LogMsgActive(const string& msg)
{
//生成命令对象,插入到命令队列中
cmdQueue.enqueue(new LogMsgCmd(this,msg));
}
int Logger::svc()
{
while(true)
{
//遍历命令队列,执行命令
auto_ptr<ACE_Method_Object> mo
(this->cmdQueue.dequeue ());
if (mo->call () == -1)
break;
}
return 0;
}
int main (int argc, ACE_TCHAR *argv[])
{
Logger log;
log. LogMsgActive ("hello");
ACE_OS::sleep(1);
log.LogMsgActive("abcd");
while(true)
ACE_OS::sleep(1);
return 0;
}
发表评论
-
u盘乱码恢复方法
2015-05-20 15:29 1750u盘乱码恢复方法,在使用u盘、SD卡、tf卡等移动储 ... -
使用 ACE 库框架在 UNIX 中开发高性能并发应用
2009-11-19 14:36 3156使用 ACE 库框架在 UNIX ... -
ACE中TCP通信
2009-09-17 11:10 2258概述: 传输控制协议TCP(Transmission C ... -
ACE的TSS bug
2009-08-26 13:55 1602ACE的TSS bug Bugzilla Bug ... -
ACE读取ini格式的配置文档
2009-08-12 15:16 2131ACE读取ini格式的配置文档 不多说了,功能很清 ... -
reactor_logging_server会出现运行 error LNK2019
2009-08-06 17:06 2569reactor_logging_server会出 ... -
ACE前摄器Proactor模式
2009-08-05 11:36 4494ACE前摄器Proactor模式 ... -
ACE_Message_Block功能简介
2009-08-05 11:35 3059ACE_Message_Block功能简介 ACE_Me ... -
ACE接受器-连接器模式
2009-08-05 11:34 4031ACE接受器-连接器模 ... -
ACE反应器(Reactor)模式(4)
2009-08-05 11:31 5215ACE反应器(Reactor)模式(4) 定时器的实现 ... -
ACE反应器(Reactor)模式(3)
2009-08-05 11:31 3912ACE反应器(Reactor)模式(3 ... -
ACE反应器(Reactor)模式(2)
2009-08-05 11:30 3505ACE反应器(Reactor)模式(2) 在Socket ... -
ACE反应器(Reactor)模式(1)
2009-08-05 11:29 3359ACE反应器(Reactor)模式(1 ... -
ACE主动对象模式(2)
2009-08-05 11:28 2146ACE主动对象模式(2) 在上篇文章里,我们简单的介绍了 ... -
ACE中UDP通信
2009-08-05 11:26 2935ACE中UDP通信 udp是一种无连接的协议,提供无连接 ... -
ACE中TCP通信
2009-08-05 11:25 3198ACE中TCP通信 概述: 传输控制协议TCP(Tra ... -
ACE线程管理机制-面向对象的线程类ACE_Task
2009-08-05 11:24 2729ACE线程管理机制-面向 ... -
ACE线程管理机制-线程的创建与管理
2009-08-05 11:23 2479ACE线程管理机制-线程的创建与管理 有过在不同的操作系 ... -
ACE自适配通信环境简介
2009-08-05 11:21 1915ACE自适配通信环境简 ... -
获取主机信息(C++和C#版)
2009-08-05 11:15 2204获取主机信息(C++和C#版) 在C语言中,主机信息是存 ...
相关推荐
ACE提供了Active Object设计模式的实现,通过Event Loop(事件循环)和Handler(处理器)机制,使得主动对象可以有效地处理来自网络的输入和内部触发的事件。 2. **半反应器模式**(Half-Reactors):半反应器模式...
4. **简化同步问题**:主动对象模式有助于简化复杂的同步问题,因为方法的执行被移至后台处理。 #### 三、ACE框架中的主动对象实现 ACE(Adaptive Communication Environment)框架提供了一种实现主动对象的机制。...
在《主动对象模式.docx》文档中,你可以学习到主动对象模式的基本概念、优缺点以及在并发编程中的应用,这将有助于你理解ACE_Task的设计思想。 总结来说,ACE框架中的ACE_Task类是实现并发编程的强大工具,它结合了...
主动对象模式涉及到 ACE_Task, ACE_Method_Object, ACE_Future 以及 ACE_Future_Observer 类,该模式很灵活,既适用于同步调用函数的场合,也适用于异步调用函数的场合或有回调接口的场合。 Singleton 模式是对 ...
"主动任务"(Active Object)是ACE中的一种多线程编程模型,它强调了对象的活性,即对象能够主动地响应请求而不是被动等待。在ACE中,`ACE_Active_Object`基类提供了一个模板,可以用来创建能够并发执行操作的对象。...
第6章主动对象(Active Object):用于并发编程的对象行为模式 第 7 章 ACE 反应器(Reactor)的设计和使用:用于事件多路分离的面向对象框架 第 8 章 前摄器(Proactor):用于为异步事件多路分离和分派处理器的...
FTP服务器需要处理主动模式和被动模式的数据连接建立,确保数据能在客户端和服务器之间正确传输。 4. **安全性**:FTP服务器需要处理认证,通常采用用户名和密码的方式。此外,现代的FTP服务器还可能支持SSL/TLS...
- **ACE_SOCK_Connector**:主动连接模式的实现,作为工厂类用于初始化一个`ACE_SOCK_Stream`对象。 - 支持“阻塞”、“非阻塞”和“定时”等方式发起连接。 - **ACE_SOCK_Stream**:用于实际的数据传输。 - `Send...
- **工作原理**:主动对象模式通过将请求排队来管理任务调度,每个请求都会被异步处理。 - **实现**:在ACE中,可以通过继承`ACE_Event_Handler`类并实现其虚拟函数来创建主动对象。 #### 八、反应器 反应器是ACE...
- **Connector**:主动发起连接请求到服务器端。 **3.3 Reactor Server Demo** - **需求**:实现一个简单的TCP服务器,能够接收多个客户端连接,并分别处理它们的请求。 - **实现步骤**: - 创建`ACE_Reactor`实例...
与传统的反应器模式不同,ACE_Proactor 遵循前摄式(Proactor)设计模式,它首先启动 I/O 操作,然后等待事件的完成,之后回调处理完成的事件。 在前摄器模式下,异步 I/O 的处理流程如下: 1. **前摄发起器**...
总结起来,这篇论文提出的分布式仿真系统的自适应通信中间件设计,结合HLA的发布/订阅机制和ACE组件,以及主动对象模式,有效地解决了分布式环境下实时信息交换的挑战,提供了高效、动态且跨平台的通信解决方案。
引擎内部实现参考了 ACE 的种种概念,比如 proactor(预先操作,前摄器),task(任务),主动对象(Active Object),message queue(消息队列),lock(锁),guard(锁守护). 在内部需要缓存的发送和接收的数据会被放入内存池...
具体实施中,文章采用Ice中间件来实现网络通信,利用ACE框架来实现主动对象模式,使用内存映射文件来保证数据的完整性和实时性,最终设计出一套既能满足金融投资研究机构对数据处理性能要求,又具有高可靠性和扩展性...
4. **事件服务(Event Service)**:如果系统需要支持推送模式,即服务器主动向客户端发送更新,那么可以利用TAO的事件服务。股票价格变动时,服务器可以发布事件,客户端订阅后会接收到通知。 5. **异常处理**:在...
RSPDMS系统基于中间件技术,采用面向对象的设计模式,提供了统一的编程接口,屏蔽了底层网络的异构性,简化了开发过程。它由监控节点、监控中心和用户终端三部分构成,实现了对硬件节点、软件节点和网络信息的实时...
6. 主动模式(Protocol):Swift中的协议允许我们定义一套方法和属性的蓝图,然后让不同的类型遵循这个协议。在这个项目中,虽然只有一个卡片,但如果想让代码更加通用,可以定义一个`Deck`协议,让`Array<Card>`...