• 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();
    }

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

  • 相关阅读:
    element 步骤条steps 点击事件
    element-ui的rules中正则表达式
    从master分支创建自己的分支
    2.1 系统调用io实现原理
    2-3形参和实参
    2-2函数
    2-1.编译和链接
    linux高编信号-------setitimer()、getitimer()
    linux高编IO-------有限状态机编程原理(mycpy)
    linux高编线程-------线程同步-条件变量
  • 原文地址:https://www.cnblogs.com/zzyoucan/p/3828862.html
Copyright © 2020-2023  润新知