首页 | 新闻 | 新品 | 文库 | 方案 | 视频 | 下载 | 商城 | 开发板 | 数据中心 | 座谈新版 | 培训 | 工具 | 博客 | 论坛 | 百科 | GEC | 活动 | 主题月 | 电子展
返回列表 回复 发帖

Linux多线程"生产者和消费者"实例

Linux多线程"生产者和消费者"实例

生产者消费者问题描述:  有一个有限缓冲区和两个线程:生产者和消费者。他们分别把产品放入缓冲区和从缓冲区中拿走产品。当一个生产者在缓冲区满时必须等待,当一个消费者在缓冲区空时也必须等待:
  (1)信号量的考虑
  这里使用3个信号量,其中两个信号量avail和full分别用于解决生产者和消费者线程之间的同步问题,mutex是用于这两个线程之间的互斥问题。其中avail初始化N(有界缓冲区的空单元数),mutex初始化为1,full初始化为0。
  #include <stdio.h>
  #include <stdlib.h>
  #include <unistd.h>
  #include <pthread.h>
  #include <errno.h>
  #include <sys/ipc.h>
  #include <semaphore.h>
  #include <fcntl.h>
  #include <string.h>
  #define FIFO "myfifo"
  #define N 5
  int lock_var;
  time_t end_time;
  char buf_r[100];
  sem_t mutex,full,avail;
  int fd;
  void pthread1(void *arg);
  void pthread2(void *arg);
  void productor(void *arg);
  void consumer(void *arg);
  int main(int argc,char *argv[])
  {
  pthread_t id1,id2;
  pthread_t mon_th_id;
  int ret;
  end_time = time(NULL) + 30;
  /*创建有名管道*/
  if((mkfifo(FIFO,O_CREAT|O_EXCL)<0) && (errno!=EEXIST))
  printf("cannot create fifoserver\n");
  printf("Preparing for reading bytes...\n");
  memset(buf_r,0,sizeof(buf_r));
  /*打开管道*/
  fd = open(FIFO,O_RDWR | O_NONBLOCK,0);
  if(fd==-1)
  {
  perror("open error!\n");
  exit(1);
  }
  /*初始化互斥信号量 1*/
  ret = sem_init(&mutex,0,3);
  /*初始化avail信号量为N*/
  ret = sem_init(&avail,0,N);
  /*初始化full信号量为0*/
  ret = sem_init(&full,0,0);
  if(ret!=0)
  {
  perror("sem_init error \n");
  }
继承事业,薪火相传
返回列表