操作系统生产者和消费者问题(共3页).doc

上传人:飞****2 文档编号:12098173 上传时间:2022-04-23 格式:DOC 页数:3 大小:687.50KB
返回 下载 相关 举报
操作系统生产者和消费者问题(共3页).doc_第1页
第1页 / 共3页
操作系统生产者和消费者问题(共3页).doc_第2页
第2页 / 共3页
点击查看更多>>
资源描述

《操作系统生产者和消费者问题(共3页).doc》由会员分享,可在线阅读,更多相关《操作系统生产者和消费者问题(共3页).doc(3页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、精选优质文档-倾情为你奉上生产者-消费者问题是一个经典的进程同步问题,已经属于化石级别的了。该问题最早由Dijkstra提出,用以演示他提出的信号量机制。要求设计在同一个进程地址空间内执行的两个线程。生产者线程生产物品,然后将物品放置在一个空缓冲区中供消费者线程消费。消费者线程从缓冲区中获得物品,然后释放缓冲区。当生产者线程生产物品时,如果没有空缓冲区可用,那么生产者线程必须等待消费者线程释放出一个空缓冲区。当消费者线程消费物品时,如果没有满的缓冲区,那么消费者线程将被阻塞,直到新的物品被生产出来。 要求设计并实现一个进程,该进程拥有一个生产者线程和一个消费者线程,它们使用N个不同的缓冲区(N

2、为一个自定义的确定的数值,例如N=32)。需要使用如下信号量: 一个互斥信号量,用以阻止生产者线程和消费者线程同时操作缓冲区列表; 一个信号量,当生产者线程生产出一个物品时可以用它向消费者线程发出信号; 一个信号量,消费者线程释放出一个空缓冲区时可以用它向生产者线程发出信号;看代码吧:/pv操作:生产者与消费者经典问题/author:leaf#include #include #include #include #include #define M 32 /*缓冲数目*/#define P(x) sem_wait(&x)#define V(x)sem_post(&x)int in = 0; /

3、*生产者放置产品的位置*/int out = 0; /*消费者取产品的位置*/int buffM = 0; /*缓冲初始化为0, 开始时没有产品*/sem_t empty_sem; /*同步信号量,当满了时阻止生产者放产品*/sem_t full_sem; /*同步信号量,当没产品时阻止消费者消费*/pthread_mutex_t mutex; /*互斥信号量, 一次只有一个线程访问缓冲*/*output the buffer*/void print()int i;for(i = 0; i M; i+)printf(%d , buffi);printf(n);/* *producer */vo

4、id *producer()for(;)sleep(1);P(empty_sem);pthread_mutex_lock(&mutex);in = in % M;printf(+)produce a product. buffer:);buffin = 1; print(); +in;pthread_mutex_unlock(&mutex);V(full_sem); /* *consumer*/void *consumer()for(;)sleep(2);P(full_sem);pthread_mutex_lock(&mutex);out = out % M;printf(-)consume

5、a product. buffer:);buffout = 0;print();+out;pthread_mutex_unlock(&mutex);V(empty_sem);void sem_mutex_init()/* *semaphore initialize */int init1 = sem_init(&empty_sem, 0, M);int init2 = sem_init(&full_sem, 0, 0); if( (init1 != 0) & (init2 != 0) printf(sem init failed n);exit(1);/* *mutex initialize

6、*/int init3 = pthread_mutex_init(&mutex, NULL);if(init3 != 0)printf(mutex init failed n);exit(1);int main()pthread_t id1;pthread_t id2;int i;int ret;sem_mutex_init();/*create the producer thread*/ret = pthread_create(&id1, NULL, producer, NULL);if(ret != 0)printf(producer creation failed n);exit(1);/*create the consumer thread*/ret = pthread_create(&id2, NULL, consumer, NULL);if(ret != 0)printf(consumer creation failed n);exit(1);pthread_join(id1,NULL);pthread_join(id2,NULL);exit(0);程序执行结果:其中1表示已经生产出的产品,1的个数就代表已生产出的产品个数。专心-专注-专业

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁