经典进程的同步问题

本文详细介绍了多道程序环境下的一些经典进程同步问题,包括利用记录型和AND信号量解决的生产者-消费者问题,读者-写者问题的多种解决方案,以及哲学家进餐问题的处理策略,旨在探讨并发控制的有效方法。
摘要由CSDN通过智能技术生成

在多道程序环境下,进程同步问题十分重要,也是相当有趣的问题,因而吸引了不少学者对它进行研究,由此而产生了一系列经典的进程同步问题,其中较有代表性的是“生产者消费者”问题、“读者写者问题”、“哲学家进餐问题”等等。

生产者-消费者问题
  
1. 利用记录型信号量解决生产者-消费者问题
  假定在生产者和消费者之间的公用缓冲池中具有n个缓冲区,这时可利用互斥信号量mutex实现诸进程对缓冲池的互斥使用;利用信号量emptyfull分别表示缓冲池中空缓冲区和满缓冲区的数量。又假定这些生产者和消费者相互等效,只要缓冲池未满,生产者便可将消息送入缓冲池;只要缓冲池未空,消费者便可从缓冲池中取走一个消息。

具体的算法描述如下:
Var
mutex, empty, full: semaphore:= l , n, 0;
  
buffer:array[O,... ,n- l] of item; nextp,nextc:item;
  
in, out: 0,1,…,n-1:=0, 0; ;
   begin    parbegin producer:   begin
             repeat
                produce an item in nextp;

                wait(empty);
                wait(

  • 0
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值