java 无锁队列实现_解析C++无锁队列的实现代码

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

#ifndef LOCK_FREE_QUEUE_H_

#define LOCK_FREE_QUEUE_H_

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

#include

template

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 TList;

TList list;

typename TList::iterator iHead, iTail;

};

#endif

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值