Linux下生产者消费者问题的实现

上传者: qiaoshanzi1234 | 上传时间: 2019-12-21 20:29:12 | 文件大小: 2KB | 文件类型: c
利用互斥锁和计数信号完成生产者消费者问题 一组生产者进程和一组消费者进程共享一个初始为空、大小为n的缓冲区,只有缓冲区没满时,生产者才把消息放入到缓冲区,否则必须等待;只有缓冲区不空时,消费者才能从中取出消息,否则必须等待。由于缓冲区是临界资源,它只允许一个生产者放入消息,或者一个消费者从中取出消息。 生产者和消费者对缓冲区互斥访问是互斥关系,同时生产者和消费者又是一个相互协作的关系,只有生产者生产之后,消费者才能消费,他们又是同步关系。 信号量设置:信号量mutex作为互斥信号量,它用于控制互斥访问缓冲池,互斥信号量初值为1;信号量full用于记录当前缓冲池中“满”缓冲区数,初值为0。信号量empty用于记录当前缓冲池中“空”缓冲区数,初值为n。 主函数负责接收参数,初始化信号量,创建生产者线程,创建消费者线程,睡眠一段时间后,结束程序

文件下载

评论信息

  • jlnu_pan :
    没运行,代码可能可以实现,但是思路有点乱,就没用上
    2015-06-30
  • 我脾气不好 :
    没运行,代码可能可以实现,但是思路有点乱,就没用上
    2015-06-30
  • jxzzgs111 :
    很好,非常推荐。
    2015-06-27
  • jxzzgs111 :
    很好,非常推荐。
    2015-06-27
  • wswzli :
    还不错 对我们的实验有参考价值
    2015-06-15
  • wswzli :
    还不错 对我们的实验有参考价值
    2015-06-15
  • u014664684 :
    是很好的初学者学习资料
    2014-11-13
  • Lemon-Apple :
    是很好的初学者学习资料
    2014-11-13
  • fmc89 :
    运行了一下 可以实现生产者消费者算法
    2014-06-30
  • fmc89 :
    运行了一下 可以实现生产者消费者算法
    2014-06-30

免责申明

【只为小站】的资源来自网友分享,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,【只为小站】 无法对用户传输的作品、信息、内容的权属或合法性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论 【只为小站】 经营者是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。
本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二条之规定,若资源存在侵权或相关问题请联系本站客服人员,zhiweidada#qq.com,请把#换成@,本站将给予最大的支持与配合,做到及时反馈和处理。关于更多版权及免责申明参见 版权及免责申明