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

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

  • 相关阅读:
    LeetCode:Multiply Strings
    c/c++ 输入输出缓冲区
    Scala access modifiers and qualifiers in detail
    PUT vs POST in REST
    Redis优化总结
    硬中断和软中断(转)
    Redis监控技巧(转)
    Understanding mysql max_connect_errors
    TCP : two different sockets sharing a port?
    libevent 安装异常
  • 原文地址:https://www.cnblogs.com/zzyoucan/p/3828862.html
Copyright © 2011-2022 走看看