70、读者写者问题

读者、写者问题

  • 任意数量的读者可以同时读取数据;
  • 每次只有一个写者在写数据;
  • 当写者在写数据时,不允许读者去读数据;

可用于解决多个进程共享一个数据区(文件,内存区,一组寄存器等),其中若干读进程只能读数据,若干写进程只能写数据等实际问题;

读者优先

  • 指一旦有读者正在读数据,允许多个读者同时进入读数据,只有当全部读者退出后,才允许写者进入写数据。
  • 容易导致写者饥饿
    比如飞机订票系统,500人正在查询从成都飞往深圳的余票。此时余票只有3张,那么读者优先就会让500人都去查询,每个人都以为还有余票,每个人都等所有人查询完了,付款系统才开始执行最后改写余票数量,最后买到票的只有三个人,其他497人都在白等。
    在这里插入图片描述

写者优先

  • 只要有一个写者申请写数据,则不再允许新的读者进入读数据;

在这里插入图片描述

互斥总结

  • 利用wait、signal原语对信号量操作实现,非常实用;
  • 可用软件方法实现互斥,如Dekker算法,Peterson算法等(容易出错,但增加处理负荷);
  • 也可以用硬件方法或固件方法实现互斥,如屏蔽中断,Test and Set指令等(属于可接受的忙等);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值