1    消息队列

ACE消息队列由三个部分组成:消息队列(ACE_Message_Queue)、消息块(ACE_Message_Block)、数据块(ACE_Data_Block)

1.1    ACE_Data_Block:通过计数器来决定数据块释放时是否被删除。只有计数器为0时,对象才会被删除。

1.1.1  构造函数:

 ACE_Data_Block (size_t size,

                                 ACE_Message_Block::ACE_Message_Type msg_type,

                                 const char *msg_data,

                                 ACE_Allocator *allocator_strategy,

                                 ACE_Lock *locking_strategy,

                                 ACE_Message_Block::Message_Flags flags,

                                 ACE_Allocator *data_block_allocator)

可以由对象自己分配内存(msg_data=0),也可以由使用者分配内存(赋值给msg_data),ACE_Data_Block进行管理。

1.1.2  得到数据块指针:

char *base (void) const;

1.1.3  引用数据块:计算器加1

ACE_Data_Block *duplicate (void);

1.1.4  释放数据块:当计算器减1,当计数器变成0后,就销毁数据块。

ACE_Data_Block *release (ACE_Lock *lock = );

1.2    ACE_Message_Block:数据块的引用。由消息队列管理。

1.2.1  构造函数:

由数据块构造消息块:

ACE_Message_Block (ACE_Data_Block *data_block,

                     Message_Flags flags = ,

                     ACE_Allocator *message_block_allocator = );

直接引用数据:

 ACE_Message_Block (const char *data,

                                       size_t size,

                                       unsigned long priority)

 ACE_Message_Block (size_t size,

                                       ACE_Message_Type msg_type,

                                       ACE_Message_Block *msg_cont,

                                       const char *msg_data,

                                       ACE_Allocator *allocator_strategy,

                                       ACE_Lock *locking_strategy,

                                       unsigned long priority,

                                       const ACE_Time_Value &execution_time,

                                       const ACE_Time_Value &deadline_time,

                                       ACE_Allocator *data_block_allocator,

                                       ACE_Allocator *message_block_allocator)

1.2.2  得到数据块指针:

ACE_Data_Block *data_block()

1.2.3  释放消息块:

ACE_Message_Block *release (void)

1.2.4   析构函数:

会调用内部数据块的release

 ACE_Message_Block::~ACE_Message_Block (void)

 {

   ACE_TRACE ("ACE_Message_Block::~ACE_Message_Block");

   if (ACE_BIT_DISABLED (this->flags_,

                         ACE_Message_Block::DONT_DELETE)&&

       this->data_block ())

     this->data_block ()->release ();

   this->prev_ = ;

   this->next_ = ;

   this->cont_ = ;

 }

1.3         ACE_Message_Queue:消息队列

1.3.1  入列

 enqueue (ACE_Message_Block *new_item, ACE_Time_Value *timeout)

 enqueue_head (ACE_Message_Block *new_item, ACE_Time_Value *timeout)

 enqueue_tail (ACE_Message_Block *new_item, ACE_Time_Value *timeout)

1.3.2   出列

 dequeue (ACE_Message_Block *&first_item, ACE_Time_Value *timeout = );

 dequeue_head (ACE_Message_Block *&first_item, ACE_Time_Value *timeout = );

 dequeue_tail (ACE_Message_Block *&dequeued, ACE_Time_Value *timeout = );

1.4         ACE_Task:封装了消息队列:

 // For the following five method if @a timeout == 0, the caller will

   // block until action is possible, else will wait until the

   // <{absolute}> time specified in *@a timeout elapses).  These calls

   // will return, however, when queue is closed, deactivated, when a

   // signal occurs, or if the time specified in timeout elapses, (in

   // which case errno = EWOULDBLOCK).

   /// Insert message into the message queue.  Note that @a timeout uses

   /// <{absolute}> time rather than <{relative}> time.

   int putq (ACE_Message_Block *, ACE_Time_Value *timeout = );

   /**

    * Extract the first message from the queue (blocking).  Note that

    * @a timeout uses <{absolute}> time rather than <{relative}> time.

    * Returns number of items in queue if the call succeeds or -1 otherwise.

    */

   int getq (ACE_Message_Block *&mb, ACE_Time_Value *timeout = );

   /// Return a message to the queue.  Note that @a timeout uses

   /// <{absolute}> time rather than <{relative}> time.

   int ungetq (ACE_Message_Block *, ACE_Time_Value *timeout = );

   /**

    * Turn the message around, sending it in the opposite direction in

    * the stream. To do this, the message is put onto the task next in

    * the stream after this task's sibling.

    *

    * @param mb Pointer to the block that is used in the reply.

    * @param tv The absolute time at which the put operation used to

    *           send the message block to the next module in the stream

    *           will time out. If 0, this call blocks until it can be

    *           completed.

    */

   int reply (ACE_Message_Block *mb, ACE_Time_Value *tv = );

   /**

    * Transfer message to the adjacent ACE_Task in a ACE_Stream.  Note

    * that @a timeout uses <{absolute}> time rather than <{relative}>

    * time.

    */

   int put_next (ACE_Message_Block *msg, ACE_Time_Value *timeout = );

转自:http://blog.csdn.net/kl222/article/details/8159812

ACE消息队列(转)的更多相关文章

  1. 阿里云ACE共创空间——MQ消息队列产品测试

    一.产品背景消息队列是阿里巴巴集团自主研发的专业消息中间件. 产品基于高可用分布式集群技术,提供消息订阅和发布.消息轨迹查询.定时(延时)消息.资源统计.监控报警等一系列消息云服务,是企业级互联网架构 ...

  2. 【微服务专题之】.Net6下集成消息队列上-RabbitMQ

    ​ 微信公众号:趣编程ACE关注可了解更多的.NET日常实战开发技巧,如需源码 请公众号后台留言 源码;[如果觉得本公众号对您有帮助,欢迎关注] .Net中RabbitMQ的使用 [微服务专题之].N ...

  3. 消息队列——RabbitMQ学习笔记

    消息队列--RabbitMQ学习笔记 1. 写在前面 昨天简单学习了一个消息队列项目--RabbitMQ,今天趁热打铁,将学到的东西记录下来. 学习的资料主要是官网给出的6个基本的消息发送/接收模型, ...

  4. 消息队列 Kafka 的基本知识及 .NET Core 客户端

    前言 最新项目中要用到消息队列来做消息的传输,之所以选着 Kafka 是因为要配合其他 java 项目中,所以就对 Kafka 了解了一下,也算是做个笔记吧. 本篇不谈论 Kafka 和其他的一些消息 ...

  5. .net 分布式架构之业务消息队列

    开源QQ群: .net 开源基础服务  238543768 开源地址: http://git.oschina.net/chejiangyi/Dyd.BusinessMQ ## 业务消息队列 ##业务消 ...

  6. 【原创经验分享】WCF之消息队列

    最近都在鼓捣这个WCF,因为看到说WCF比WebService功能要强大许多,另外也看了一些公司的招聘信息,貌似一些中.高级的程序员招聘,都有提及到WCF这一块,所以,自己也关心关心一下,虽然目前工作 ...

  7. Java消息队列--ActiveMq 实战

    1.下载安装ActiveMQ ActiveMQ官网下载地址:http://activemq.apache.org/download.html ActiveMQ 提供了Windows 和Linux.Un ...

  8. Java消息队列--JMS概述

    1.什么是JMS JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中发送 ...

  9. 消息队列性能对比——ActiveMQ、RabbitMQ与ZeroMQ(译文)

    Dissecting Message Queues 概述: 我花了一些时间解剖各种库执行分布式消息.在这个分析中,我看了几个不同的方面,包括API特性,易于部署和维护,以及性能质量..消息队列已经被分 ...

随机推荐

  1. 举例说明如何使用【聚合数据】的API接口

    0 注册[聚合数据]的账号 登陆www.juhe.cn,如图,如果没有账号,注册一个(手机号或者邮箱注册),如果有直接登陆即可. 1 搜索所需的API接口 找到聚合数据主页,在搜索框输入你想搜索的AP ...

  2. log4j 输入不同日志文件

    log4j的强大功能无可置疑,但实际应用中免不了遇到某个功能需要输出独立的日志文件的情况,怎样才能把所需的内容从原有日志中分离,形成单独的日志文件呢?其实只要在现有的log4j基础上稍加配置即可轻松实 ...

  3. IE8的 JS 引擎如此不堪?

    之前给客户做了个网站,其中有这么一个功能: 文章内容中,有指向某个图片的链接,链接内容为图片名称(文字),点击之后在页面上弹出该图片显示,图片可以为png,jpg,gif等. 于是,祭出了JQuery ...

  4. notepad++ quicktext插件安装与代码片段配置[quicktext v0.2.1]

    1 下载quicktext插件0.2.1版本 http://sourceforge.net/projects/quicktext/ 2 解压 3 把QuickText.ANSI.dll和QuickTe ...

  5. php中parse_url函数的源码及分析

    前言 看师傅们的文章时发现,parse_url出现的次数较多,单纯parse_url解析漏洞的考题也有很多,在此研究一下源码(太菜了看不懂,待日后再补充Orz) 源码 PHPAPI php_url * ...

  6. 51nod 1283 最小周长【注意开根号】

    1283 最小周长 题目来源: Codility 基准时间限制:1 秒 空间限制:131072 KB 分值: 5 难度:1级算法题  收藏  关注 一个矩形的面积为S,已知该矩形的边长都是整数,求所有 ...

  7. [BZOJ 3571] 画框

    Link: BZOJ 3571 传送门 Solution: 和 BZOJ2395 的建模完全相同,(BZOJ2395 题解传送门) 仅仅是将其中的基础问题由最小生成树改成了二分图最大完美匹配 只要将原 ...

  8. HDU 2819 Swap(二分图匹配)

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=2819 [题目大意] 给出一个棋盘,由白格子和黑格子组成,可以交换棋盘的行列, 使得其主对角线为黑格 ...

  9. Codeforces 788C The Great Mixing(背包问题建模+bitset优化或BFS)

    [题目链接] http://codeforces.com/problemset/problem/788/C [题目大意] 给出一些浓度的饮料,要求调出n/1000浓度的饮料,问最少需要多少升饮料 [题 ...

  10. 【动态规划】Gym - 100507G - The Debut Album

    一般思路的dp是用f(i,j,0)表示前i位最后有j个1的方案数,用f(i,j,1)表示前j位最后有j个2的方案数,j都是大于等于1的,然后比较容易转移. 但这题卡内存,就只能用f(i,j)表示前i位 ...