zoukankan      html  css  js  c++  java
  • boost::lockfree::spsc_queue

    #include <boost/thread/thread.hpp>
    #include <boost/lockfree/spsc_queue.hpp>
    #include <iostream>
    
    #include <boost/atomic.hpp>
    
    int producer_count = 0;
    boost::atomic_int consumer_count (0);
    
    boost::lockfree::spsc_queue<int, boost::lockfree::capacity<1024> > spsc_queue;//但生产者但消费者队列,后面是指定其容量大小
    
    const int iterations = 10000000;
    
    void producer(void)
    {
        for (int i = 0; i != iterations; ++i) {
            int value = ++producer_count;
            while (!spsc_queue.push(value))
                ;
        }
    }
    
    boost::atomic<bool> done (false);
    
    void consumer(void)
    {
        int value;
        while (!done) {
            while (spsc_queue.pop(value))
                ++consumer_count;
        }
    
        while (spsc_queue.pop(value))
            ++consumer_count;
    }
    
    int main(int argc, char* argv[])
    {
        using namespace std;
        cout << "boost::lockfree::queue is ";
        if (!spsc_queue.is_lock_free())
            cout << "not ";
        cout << "lockfree" << endl;
    
        boost::thread producer_thread(producer);//单生产者
        boost::thread consumer_thread(consumer);//单消费者
    
        producer_thread.join();
        done = true;
        consumer_thread.join();
    
        cout << "produced " << producer_count << " objects." << endl;
        cout << "consumed " << consumer_count << " objects." << endl;
        getchar();
    }

    其实只要知道其实一种无锁队列是一种单生产者,单消费者的模式。

  • 相关阅读:
    nginx rewrite 伪静态重写学习笔记
    正则表达式相关知识
    rpm的含义
    find命令的使用
    chmod的运用方式
    [GO]数组的比较和赋值
    [GO]二维数组的介绍
    [GO]变量内存和变量地址
    [GO]给导入包起别名
    阿里云负载均衡SLB 七层https协议 nginx 获取真实IP
  • 原文地址:https://www.cnblogs.com/zzyoucan/p/3828862.html
Copyright © 2011-2022 走看看