【linux】生产者与消费者模型实现代码

#include <iostream>
#include <pthread.h>
#include <mutex>
#include <queue>
#include <unistd.h>

#define CAPACITY 10
#define THREADCOUNT 2


// 生产者和消费者模型
class BlockQueue
{
  public:
    BlockQueue()
    {
      capacity_ = CAPACITY;
      pthread_mutex_init(&lock_, NULL);
      pthread_cond_init(&cons, NULL);
      pthread_cond_init(&prod, NULL);
    }

    // 队列入元素
    void Push(int data)
    {
      pthread_mutex_lock(&lock_);
      while(que_.size() >= capacity_)
      {
        pthread_cond_wait(&prod, &lock_);
      }

      que_.push(data);
      pthread_mutex_unlock(&lock_);

      pthread_cond_signal(&cons);
    }

    void Pop(int* data)
    {
      pthread_mutex_lock(&lock_);
      while(que_.empty())
      {
        pthread_cond_wait(&cons, &lock_);
      }
      *data = que_.front();
      que_.pop();
      pthread_mutex_unlock(&lock_);
      pthread_cond_signal(&prod);
    }

    ~BlockQueue()
    {
      pthread_mutex_destroy(&lock_);
      pthread_cond_destroy(&cons);
      pthread_cond_destroy(&prod);
    }
  private:
    std::queue<int> que_;
    size_t capacity_;
    pthread_mutex_t lock_;
    pthread_cond_t cons;
    pthread_cond_t prod;
};

void* ConsStart(void* arg)
{
  BlockQueue* bq = (BlockQueue*)arg;
  while(1)
  {
    int data;
    bq->Pop(&data);
    printf("i am thread %p, i consume %d\n", pthread_self(), data);
  }
  return NULL;
}

void* ProdStart(void* arg)
{
  BlockQueue* bq = (BlockQueue*)arg;
  int data = 0;
  while(1)
  {
    bq->Push(data);
    data++;
    printf("i am thread %p, i product %d\n", pthread_self(), data);
  } 
  return NULL;
}


int main()
{
  pthread_t cons[THREADCOUNT], prod[THREADCOUNT];
  BlockQueue* bq = new BlockQueue();
  for(int i = 0; i < THREADCOUNT; ++i)
  {
    int ret = pthread_create(&prod[i], NULL, ConsStart, (void*)bq);
    if(ret < 0)
    {
      perror("pthread create !!!");
      return -1;
    }
    ret = pthread_create(&cons[i], NULL, ProdStart, (void*)bq);
    if(ret < 0)
    {
      perror("pthread create !!!");
      return -1;
    }
  }

  for(int i = 0; i < THREADCOUNT; ++i)
  {
    pthread_join(prod[i], NULL);
    pthread_join(prod[i], NULL);
  }
  return 0;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值