学习笔记:boost spsc队列

#include <boost/thread/thread.hpp>
#include <boost/shared_ptr.hpp>
#include <boost/lockfree/spsc_queue.hpp>
#include <boost/atomic.hpp>
#include <boost/bind.hpp>
#include <iostream>

class Consumer
{
public:

    struct Data{ int a,b,c; };

	Consumer():stoped_(false),counter_(0){}

	~Consumer(){
	    stop();
	}

	void start(){
		trd_.reset(new boost::thread( boost::bind(&Consumer::run, this)));
	}

	void stop(){
	    stoped_=true;
		trd_->join();
		std::cout << "TOTAL CONSUME "<< counter_ << std::endl;
	}

	bool push(Data& d){
	    return spsc_queue_.push(d);
	}

private:

	void deal(Data& d){
	    counter_+=d.c;
	}
	
	void run(){
		while (!stoped_) {
			if ( 0==spsc_queue_.consume_all( boost::bind(&Consumer::deal,this,_1)))
				boost::this_thread::sleep(boost::posix_time::seconds(0));
        }
        spsc_queue_.consume_all( boost::bind(&Consumer::deal,this,_1));
	}

private:
    boost::lockfree::spsc_queue<Data, 
		                        boost::lockfree::capacity<1024> , 
		                        boost::lockfree::fixed_sized<true> > spsc_queue_;

	bool stoped_;
	boost::shared_ptr<boost::thread> trd_;
	int counter_;
};

int main(int argc, char* argv[])
{
	Consumer consumer;
    consumer.start();
	
	Consumer::Data d;
	d.c=1;

	for (int i = 0; i!=10000000; ++i) {

		while (!consumer.push(d)){
		    boost::this_thread::sleep(boost::posix_time::seconds(0));
		}
    }
	
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值