手机
当前位置:查字典教程网 >编程开发 >C语言 >解析C++无锁队列的实现代码
解析C++无锁队列的实现代码
摘要:本文给出一种C++无锁队列的实现代码,主要用于一个线程读取数据另外一个线程写数据复制代码代码如下:#ifndefLOCK_FREE_QUEU...

本文给出一种C++无锁队列的实现代码,主要用于一个线程读取数据另外一个线程写数据

复制代码 代码如下:

#ifndef LOCK_FREE_QUEUE_H_

#define LOCK_FREE_QUEUE_H_

//不加锁队列,适合一个线程读取,一个线程写

#include <list>

template <typename T>

class LockFreeQueue

{

public:

LockFreeQueue()

{

list.push_back(T());//分割节点

iHead = list.begin();

iTail = list.end();

};

void Produce(const T& t) //存消息

{

list.push_back(t);

iTail = list.end();

list.erase(list.begin(), iHead);

};

bool Consume(T& t) //取消息

{

typename TList::iterator iNext = iHead;

++iNext;

if (iNext != iTail)

{

iHead = iNext;

t = *iHead;

return true;

}

return false;

};

bool Peek(T& t) //查看消息不删除

{

typename TList::iterator iNext = iHead;

++iNext;

if (iNext != iTail)

{

t = *iNext;

return true;

}

return false;

}

bool IsEmpty()

{

typename TList::iterator iNext = iHead;

++iNext;

if (iNext != iTail)

{

return false;

}

else

{

return true;

}

}

int GetMaxSize()

{

return list.max_size();

};

private:

typedef std::list<T> TList;

TList list;

typename TList::iterator iHead, iTail;

};

#endif

【解析C++无锁队列的实现代码】相关文章:

解析使用C++编写无错代码的方法技巧

基于C中一个行压缩图的简单实现代码

c++大数阶乘的实现方法

解析c++中参数对象与局部对象的析构顺序的详解

二分法求多项式在-10 10间值的实现代码

c语言全盘搜索指定文件的实例代码

c++ 巧开平方的实现代码

ShellExecute函数用法的实例代码

C语言中打印特殊图案的实现代码

深入解析函数指针与返回函数的指针

精品推荐
分类导航