基于条件变量的消息队列说明介绍
2023-06-13 09:14:50 时间
条件变量是线程之前同步的另一种机制。条件变量给多线程提供了一种会和的场所。当条件变量和互斥锁一起使用时,允许线程以无竞争的方式等待特定的条件发生。这样大大减少了锁竞争引起的线程调度和线程等待。
消息队列是服务器端开发过程中绕不开的一道坎,前面,我已经实现了一个基于互斥锁和三队列的消息队列,性能很不错。博客园中的其他园主也实现了很多基于环形队列和lock-free的消息队列,很不错,今天我们将要实现一个基于双缓冲、互斥锁和条件变量的消息队列;这个大概也参考了一下java的blockingqueue,在前面一个博客中有简单介绍!!基于三缓冲的队列,虽然最大限度上解除了线程竞争,但是在玩家很少,消息很小的时候,需要添加一些buff去填充数据,这大概也是其一个缺陷吧!
消息队列在服务器开发过程中主要用于什么对象呢?
1:我想大概就是通信层和逻辑层之间的交互,通信层接受到的网络数据,验证封包之后,通过消息队列传递给逻辑层,逻辑层将处理结果封包再传递给通信层!
2:逻辑线程和数据库IO线程的分离;数据库IO线程负责对数据库的读写更新,逻辑层对数据库的操作,封装成消息去请求数据库IO线程,数据库IO线程处理完之后,再交回给逻辑层。
3:日志;处理模式与方式2类似。不过日志大概是不需要返回的!
给出源代码:
BlockingQueue.h文件
/*
*BlockingQueue.h
*
* Createdon:Apr19,2013
* Author:archy_yu
*/
#ifndefBLOCKINGQUEUE_H_
#defineBLOCKINGQUEUE_H_
#include<queue>
#include<pthread.h>
typedefvoid*CommonItem;
classBlockingQueue
{
public:
BlockingQueue();
virtual~BlockingQueue();
intpeek(CommonItem&item);
intappend(CommonItemitem);
private:
pthread_mutex_t_mutex;
pthread_cond_t_cond;
std::queue<CommonItem>_read_queue;
std::queue<CommonItem>_write_queue;
};
#endif/*BLOCKINGQUEUE_H_*/
BlockingQueue.cpp文件代码
/*
*BlockingQueue.cpp
*
* Createdon:Apr19,2013
* Author:archy_yu
*/
#include"BlockingQueue.h"
BlockingQueue::BlockingQueue()
{
pthread_mutex_init(&this->_mutex,NULL);
pthread_cond_init(&this->_cond,NULL);
}
BlockingQueue::~BlockingQueue()
{
pthread_mutex_destroy(&this->_mutex);
pthread_cond_destroy(&this->_cond);
}
intBlockingQueue::peek(CommonItem&item)
{
if(!this->_read_queue.empty())
{
item=this->_read_queue.front();
this->_read_queue.pop();
}
else
{
pthread_mutex_lock(&this->_mutex);
while(this->_write_queue.empty())
{
pthread_cond_wait(&this->_cond,&this->_mutex);
}
while(!this->_write_queue.empty())
{
this->_read_queue.push(this->_write_queue.front());
this->_write_queue.pop();
}
pthread_mutex_unlock(&this->_mutex);
}
return0;
}
intBlockingQueue::append(CommonItemitem)
{
pthread_mutex_lock(&this->_mutex);
this->_write_queue.push(item);
pthread_cond_signal(&this->_cond);
pthread_mutex_unlock(&this->_mutex);
return0;
}
测试代码:
BlockingQueue_queue;
void*process(void*arg)
{
inti=0;
while(true)
{
int*j=newint();
*j=i;
_queue.append((void*)j);
i++;
}
returnNULL;
}
intmain(intargc,char**argv)
{
pthread_tpid;
pthread_create(&pid,0,process,0);
longlongintstart=get_os_system_time();
inti=0;
while(true)
{
int*j=NULL;
_queue.peek((void*&)j);
i++;
if(j!=NULL&&(*j)==100000)
{
longlongintend=get_os_system_time();
printf("consume%d\n",end-start);
break;
}
}
return0;
}
相关文章
- MQ消息队列详解、四大MQ的优缺点分析
- vue消息提示组件封装
- 【第十篇】Camunda系列-事件篇-消息事件
- 微信公众号推广_小程序通知栏消息推送
- SpringCloud Stream消息驱动
- 腾讯、字节回应裁员消息不实;今年全球科技行业已裁员超10万人;2022年超5700家中国芯片公司消失丨每日大事件
- EA&UML日拱一卒 为通信图增加新的消息组
- 消息队列面试常问
- [android] android消息机制入门详解手机开发
- ios入门之消息推送详解手机开发
- 读取Linux消息队列阻塞读取的研究(linux消息队列阻塞)
- MySQL 安装成功:激动人心的消息!(mysql 安装成功)
- 队列探索Redis消息队列,打开新疆线(怎么看redis消息)
- 快速清除Redis消息队列高效出结果(清除redis消息队列值)
- 基于Redis的消息队列限流策略(redis队列限流)
- Redis实现消息订阅开启长连接的机遇与挑战(redis订阅长连接吗)
- 使用Redis订阅发布机制实现消息消费完美总结(redis订阅消费总结)
- 利用Redis实现订阅消息的广播(redis订阅消息广播)
- 基于Redis的消息队列服务实战(redis消息队列场景)
- 利用Redis实现消息自动过期(redis 消息过期)
- MWC 2017前夕,英特尔都透露了哪些消息?
- Facebook 将在 Messenger 中启用端到端加密、消息定时销毁功能
- windows消息和消息队列实例详解