zoukankan      html  css  js  c++  java
  • 生产者,消费者 多线程

      

    #include <iostream>
    #include <vector>
    #include <thread>
    #include <mutex>
    
    const size_t SIZE = 10;
    using ElemTy = char;
    ElemTy arr[SIZE];
    
    size_t begin = 0;
    size_t end = 0;
    
    std::mutex prdc_m;
    std::mutex cnsm_m;
    
    void produce() {
      for (;;) {
        if ((end + 1) % SIZE != begin) {
          {
            std::lock_guard<std::mutex> lg(prdc_m);
            arr[end] = 'o';
            end = (end + 1) % SIZE;
            std::cout << "produce and size is " << (end - begin) % SIZE << std::endl;
          }
        }
      }
    }
    
    void consume() {
      for (;;) {
        if (begin != end) {
          ElemTy e;
          {
            std::lock_guard<std::mutex> lg(cnsm_m);
            e = arr[begin];
            begin = (begin + 1) % SIZE;
            std::cout << "consume and size is " << (end - begin) % SIZE << std::endl;
          }
        }
      }
    }
    
    int main() {
      std::vector<std::thread> vc;
      std::vector<std::thread> vp;
      for (int i = 0; i < 10; ++i) {
        vc.push_back(std::thread(consume));
      }
      for (int i = 0; i < 10; ++i) {
        vp.push_back(std::thread(produce));
      }
    
      for (auto &t : vc) {
        t.join();
      }
    
      for (auto &t : vp) {
        t.join();
      }
    
      return 0;
    }
    #include <iostream>
    #include <vector>
    #include <thread>
    #include <mutex>
    
    class ConcurrentQueue {
      using ElemTy = char;
      static const size_t SIZE = 10;
      ElemTy arr[SIZE];
    
      size_t begin = 0;
      size_t end = 0;
    
      std::mutex prdc_m;
      std::mutex cnsm_m;
    
    public:
      void produce() {
        for (;;) {
          if ((end + 1) % SIZE != begin) {
            {
              std::lock_guard<std::mutex> lg(prdc_m);
              arr[end] = 'o';
              end = (end + 1) % SIZE;
              std::cout << "produce and size is " << (end - begin) % SIZE << std::endl;
            }
          }
        }
      }
    
      void consume() {
        for (;;) {
          if (begin != end) {
            ElemTy e;
            {
              std::lock_guard<std::mutex> lg(cnsm_m);
              e = arr[begin];
              begin = (begin + 1) % SIZE;
              std::cout << "consume and size is " << (end - begin) % SIZE << std::endl;
            }
          }
        }
      }
    };
    
    int main() {
      std::vector<std::thread> vc;
      std::vector<std::thread> vp;
      ConcurrentQueue Q;
      for (int i = 0; i < 10; ++i) {
        vc.push_back(std::thread(&ConcurrentQueue::consume, std::ref(Q)));
      }
      for (int i = 0; i < 10; ++i) {
        vp.push_back(std::thread(&ConcurrentQueue::produce, std::ref(Q)));
      }
    
      for (auto &t : vc) {
        t.join();
      }
    
      for (auto &t : vp) {
        t.join();
      }
    
      return 0;
    }
    

      

  • 相关阅读:
    【华为云技术分享】昇腾AI处理器软件栈--总览
    【云速建站】SSL证书自助部署
    【华为云技术分享】如何做一个优秀软件-可扩展的架构,良好的编码,可信的过程
    C# Async和Await的异步编程例子
    委托的简单例子
    批量修改图片的尺寸(c#)
    使用TinyPNG提供的API,对图片进行压缩(C#)
    21. 合并两个排序单链表 Merge Two Sorted Lists
    263. 丑陋数 Ugly Number
    413. 数组切片 Arithmetic Slices
  • 原文地址:https://www.cnblogs.com/jjtx/p/6759605.html
Copyright © 2011-2022 走看看