首页 > 代码库 > linux中的线程同步:生产者、消费者问题
linux中的线程同步:生产者、消费者问题
#include <stdio.h> #include <semaphore.h> #include <unistd.h> #include <stdlib.h> #include <pthread.h> #define BUFFER_COUNT 5 int Buffer[BUFFER_COUNT]; //指针数组 int front = 0; int tail = 0; sem_t SemProd; sem_t SemCon; void* productor(void *arg) { int counter = 0; while(1) { int ret = sem_wait(&SemProd); sleep(2); //模拟输入处理时延 Buffer[tail] = counter; printf("in productor: %d, %d\n", counter++, ret); tail = (tail + 1) % BUFFER_COUNT; // sem_post(&SemCon); } return NULL; } void* consumer(void *arg) { while(1) { sem_wait(&SemCon); sleep(1); //模拟输出处理时延 printf("in consumer: %d, %d\n", Buffer[front], front); front = (front + 1) % BUFFER_COUNT; sem_post(&SemProd); } } int main(int argv, char **argc) { pthread_t id1, id2; sem_init(&SemProd, 0, BUFFER_COUNT); sem_init(&SemCon, 0, 0); pthread_create(&id1, NULL, productor, NULL); pthread_create(&id2, NULL, consumer, NULL); pthread_join(id1, NULL); pthread_join(id2, NULL); }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。