随笔 - 355  文章 - 8 评论 - 512 trackbacks - 19

ACE自适配通信环境 (Adaptive Communication Environment)是面向对象的框架和工具包,它为通信软件实现了核心的并发和分布式模式。ACE包含的多种组件可以帮助通信软件的开发获得更好的灵活性、效率、可靠性和可移植性。ACE中的组件可用于以下几种目的:

  1. 并发和同步
  2. 进程间通信(IPC)
  3. 内存管理
  4. 定时器
  5. 信号
  6. 文件系统管理
  7. 线程管理
  8. 事件多路分离和处理器分派
  9. 连接建立和服务初始化
  10. 软件的静态和动态配置、重配置
  11. 分层协议构建和流式框架
  12. 分布式通信服务:名字、日志、时间同步、事件路由和网络锁定,等等。

   

ACE体系结构

如图1-1所示,ACE具有分层的体系结构。在ACE框架中有三个基本层次:

  1. 操作系统(OS)适配层
  2. C++包装层
  3. 框架和模式层

 

图 ACE的体系结构

1 OS适配层

OS适配层是位于本地OS API和ACE之间的"瘦"代码层,它使ACE的较高层与平台依赖性屏蔽开来,从而使得通过ACE编写的代码保持了相对的平台无关性。只需要极少的努力,开发者就可以将ACE应用移植到任何平台上。

2 C++包装层

C++包装层包括一些C++包装类,它们可用于构建高度可移植的和类型安全的C++应用

  1. 并发和同步
    ACE提供若干并发和同步包装类,对本地OS多线程和多进程API进行了抽象。
  2. IPC
    ACE提供若干C++包装类,封装不同OS中不同的进程间通信(IPC)接口。
  3. 内存管理组件
    ACE包含的一些类可用于内存动态分配和释放;其中包括允许预分配所有动态内存的类。这些预分配的内存随即通过ACE提供的管理类的帮助进行本地管理。在大多数实时和嵌入式系统中,这样的细粒度管理极为必要。另外还有一些类用于灵活地管理进程间共享内存。
  4. 定时器类
    有多种不同的类可用于处理定时器的调度和取消。
  5. 容器类
    ACE还拥有若干可移植的STL风格的容器类,如Map、Hash_Map、Set、List,等等
  6. 信号处理
    ACE提供对特定OS的信号处理接口进行封装的包装类。这些类使得开发者能够很容易地安装和移除信号处理器,并且可以为一个信号安装若干处理器。
  7. 文件系统组件
    ACE含有包装文件系统API的类。这些类包括文件I/O、异步文件I/O、文件加锁、文件流、文件连接包装,等等。
  8. 线程管理
    ACE提供包装类来创建和管理线程。这些包装还封装了针对特定OS的线程API,可被用于提供像线程专有存储这样的功能。

3 ACE框架组件

ACE框架组件是ACE层次结构中的最高层,它们的基础是若干针对特定通信软件领域的设计模式。设计者可以使用这些框架组件来帮助自己在高得多的层面上思考和构建系统。ACE的这一层含有以下一些大型组件:

  1. 事件处理
    大多数通信软件都含有大量处理各种类型事件(比如,基于I/O、基于定时器、基于信号和基于同步的事件)的代码。软件必须高效地多路分离、分派和处理这些事件。遗憾的是,大多数时间开发者们都在反复地编写这些代码,"重新发明轮子"。这是因为,事件多路分离、分派和处理代码全都紧密地耦合在一起,无法彼此独立地使用。ACE提供了被称为Reactor(反应器)的框架组件来解决这一问题。反应器提供用于高效地进行事件多路分离和分派的代码,并极大地降低了它们与处理代码之间的耦合,从而改善了可复用性和灵活性。
  2. 连接或服务初始化组件
    ACE提供Connector(连接器)Acceptor(接受器)组件,用于降低连接初始化与连接建立后应用执行的实际服务之间的耦合
  3. 流组件
    ACE Stream组件用于简化那些本质上是分层的(layered)或层次的(hierarchic)软件的开发。用户级协议栈的开发是一个好例子;这样的栈由若干互连的层次组成。这些层次或多或少可以相互独立地进行开发。当"数据"通过时,每一层都处理并改变它,并将它传递给下一层,以作进一步的处理。因为各层是相互独立的,它们很容易被复用或替换。
  4. 服务配置组件
    通信软件开发者面临的另一个问题是,很多时候,软件服务必须在安装时配置,或必须在运行时重配置。应用中特定服务的实现可能需要进行改动,因而应用可能必须用新改动的服务重新配置。ACE Service Configurator(服务配置器)为应用的服务提供动态的启动、挂起和配置。

随着计算机网络领域发展迅速,编写通信软件变得更为困难。大量消耗在开发通信软件上的努力不过是"重新发明轮子"的变种,已知的可以在应用间通用的组件被重写,而不是被复用。通过收集通用的组件和体系结构(它们在网络和系统编程领域一再被复用),ACE为这一问题提供了解决方案。应用开发者可以采用ACE,挑选和选择在他的应用中所需的组件,并开始在ACE工具箱的陪伴下构建应用。

posted @ 2006-12-03 21:11 天方 阅读(1999) 评论(0) 编辑

ACE的安装是一件比较麻烦的事情,这里简单的记录了我在VS2005下安装ACE的过程,希望能给大家一个参考。

  1. 安装环境:
    1. 操作系统:Windows XP 专业版
    2. 编译环境:VS2005中文版
    3. ACE版本:ACE-5.5.1
  2. 安装过程:
    1. 下载安装包。
      1. Ace的安装文件可以在http://download.dre.vanderbilt.edu/中下载到,由于我是在windows环境下安装并且不需要TAO等其它库,便下载了ACE-5.5.1.zip。
      2. 下载完成后将其解压。我的解压路径为D:\Develop\ACE_wrappers。
    2. 设置环境变量
      1. 在操作系统添加一个名为ACE_ROOT的用户环境变量,值为刚才ace的解压路径D:\Develop\ACE_wrappers
      2. 添加用户的Path环境变量,值为%ACE_ROOT%\lib,这样才能保证系统能找到ace生成的动态连接库。
      3. 设置VS2005的C++开发项目信息,依次打开菜单 工具-选项-项目和解决方案-VC++目录 ,在右侧目录列表中选择"包含目录",添加$(ACE_ROOT),在右侧目录列表中选择"库文件",添加$(ACE_ROOT)\lib
    3. 编译ACE
      1. ACE_ROOT\ace目录创建一个名为 config.h的文件。编辑文件并加入以下内容
        #define ACE_HAS_STANDARD_CPP_LIBRARY 1
        #include "ace/config-win32.h"
        其中第一行是因为我想用标准C++跨平台,第二行则是必须要的,表明当前是在win32的环境下进行ace的项目。
      2. 进入ACE_ROOT\ace目录中,能发现ACE现在已经带VS2005的编译项目了,直接打开ace_vc8.sln,直接生成ACE项目的Debug版和Release版,编译过程还比较快,大概就几分钟的样子。编译链接完成后,在ACE_ROOT\lib中一共生成了四个文件,分别是"ACE.dll","ACE.lib", "ACEd.dll","ACEd.lib",其中带"d"表示的是Debug版本。
    4. 检验 ACE
      1. 打开VS2005,建立一个空项目,将ACE程序员手册中的第一个程序拷入其中。
      2. 配置属性->链接器->常规->附加依赖项,添入ACEd.lib。
      3. 编译,如果不出意外的话就能看到你的ace版的" hello world"啦。

注意:
ACE项目的字符集设置是"未设置",而VS2005的c++项目默认字符集是"使用 Unicode 字符集",如果用到了ACE链接库时需要将字符集改为"未设置"(在"项目属性->配置属性->项目默认值->字符集"中配置),否则可能出现链接错误。

至此,ACE的安装工作便算完成,希望这篇文章对大家安装ACE有点帮助。

支持unicode的ACE编译。

编译前在config.h中多添加如下两行,并且将项目默认字符集改为"使用 Unicode 字符集"。

#define ACE_USE_WCHAR
#define ACE_HAS_WCHAR

注意:

在windows平台下,如果没有定义如上两个宏, ACE会自动将 main 函数重定义, 并主动替你把 ACE::init() 和 ACE::fini() 调用好。添加这两个宏后,需要在main函数中手动调用。

main 函数重定义这一行为不能保证在所有平台和环境下都正常运作(如使用MFC时),其实不管如何,不妨在 main 函数的开头和结尾分别再调用一次 ACE::init() 和 ACE::fini()。 ACE::init() 和 ACE::fini() 里面都有嵌套层次计数机制,因此只要它们能够保证成对出现, 并且不出现交叉嵌套, 多调用一遍并不会出现任何问题。

posted @ 2006-12-03 19:15 天方 阅读(4911) 评论(6) 编辑

最近用ACE进行网络编程开发比较多,所以决定将ACE的学习过程简单做一下笔记,记录下来以供参考。

ACE学习日志目录。(不断更新中)

  1. ACE的安装
  2. ACE自适配通信环境简介
  3. ACE线程管理机制
  4. ACE网络编程开发框架
  5. To Be Continued …

   

posted @ 2006-12-03 19:10 天方 阅读(2855) 评论(0) 编辑