ACE学习综述(1)

1. ACE学习综述

1.1. ACE项目的优点

  • 可以跨平台使用,基本上可以实现一次编写,多平台运行。
  • ACE本身不仅仅是一个简单的网络框架,对于网络框架涉及到的进程管理、线程管理等系统本身相关的内容也进行了统一的封装,甚至消息队列和内存管理等也都有统一封装。
  • 代码的质量还是比较高,能经得起长时间运行的考验。
  • 代码经过层层封装和模板通用性封装,仍然能够保持较高的性能。

1.2. ACE项目的缺点

  • ACE的前身是 《Unix网络编程》,该书页数达上千页,包括了各种网络开发的细节、移植扩展和网络开发架构模式,这就要求使用ACE开发网络的人必须具备了较丰富的网络开发经验。
  • ACE的代码已经比较庞大,且每个版本都有新功能加入,但是相关文档更新不及时。三本开发编程的书也都定位与基本的功能,想深入了解就必须从大量代码中选择代码阅读。
  • 由于ACE定位是跨平台开发,各个开发平台上的网络实现和数据结构各不相同,因为代码中充斥了大量的宏来区分,对于阅读代码造成了一定的障碍。
  • 学术性较强,设计模式与模板使用相对密集。阅读代码前需要先学习 POSA2 的图书。
  • ACE的类继承关系略显负责,层次较多,不利于学习和分析。

1.3. Reactor使用过程中的注意事项

  • 相对时间和绝对时间使用,相对超时时间常常用于这样的情况:操作可能会在能够继续执行之前迟滞,但只会被调用一次。 绝对时间常常被用于这样的情况:操作可能会通过循环多次调用。绝对时间的使用使得无需每次循环重新计算超时值。 具体可参考 《C++ 网络编程卷二》 中文 P45,副栏6。
  • handle_*() 函数(Reactor会忽略handle_close的返回值)的返回值,决定着Reactor后续对相关MASK的处理。 == 0 正常处理 > 0 Reactor继续为此事件检测和分配已经登记的时间。 == -1 Reactor应停止对时间处理器已经登记的MASK。 如何跟踪已经注册的事件,则可参考 《C++ 网络编程卷二》 P51, 副栏 10。
  • 对于事件处理器的资源释放集中在其 handle_close 函数中进行。如果为动态分配的对象,可以在关闭所有资源后调用 delete this。
  • reactor->remove_handler(eh,mask),如果没有设置 ACE_Event_Handler::DONT_CALL 标志,会调用该 mask 的 handle_close 函数,因此如果在 handle_close 函数中调用 remove_handler 函数,需要添加ACE_Event_Handler::DONT_CALL 标志,避免 handle_close 的递归调用。

posted on   深入浅出eBPF  阅读(298)  评论(0编辑  收藏  举报

编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

点击右上角即可分享
微信分享提示