解析C++无锁队列的实现代码_C语言教程-查字典教程网
解析C++无锁队列的实现代码
解析C++无锁队列的实现代码
发布时间:2016-12-28 来源:查字典编辑
摘要:本文给出一种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语言学习
    编程开发子分类