66 - 进程互斥锁的应用示例

---- 整理自狄泰软件唐佐林老师课程

查看所有文章链接:(更新中)深入浅出操作系统 - 目录

1. 简单生产消费者问题

  • 有 n 个生产者同时制造产品,并把产品存入仓库中
  • 有 m 个消费者同时需要从仓库中取出产品
  • 规则:
    • 一次只允许一个生产者向仓库放入产品
    • 一次只允许一个消费者从仓库取出产品
    • 生产者和消费者不能同时进入仓库
      ==> 也即:一次只允许一个人进入仓库,仓库是临界资源

1.1 具体问题描述

  • 有 2 个生产者任务,2 个消费者任务
    • Producer A - 生产者,生产A型产品
    • Producer B - 生产者,生产B型产品
    • Consumer A - 消费者,消耗A型产品
    • Consumer B - 消费者,消耗B型产品

1.2 解决方案

  • 使用链表模拟仓库(临界资源)
  • 使用互斥锁保护临界资源
  • 消费者任务进入仓库后,查找所需产品并取出
  • 生产者生产 N 个产品后结束生产

1.3 简单生产消费者问题模型

在这里插入图片描述

1.4 编程实验:生产消费者示例

【参看链接】:66 - 进程互斥锁的应用示例 / 00简单生产消费者问题

在这里插入图片描述

2. 多任务读写问题(复杂生产消费者问题)

  • 有 1 个 Writer 每间隔一段时间就会更新数据
  • 有 n 个 Reader 需要同时读数据
  • 规则:
    • Writer 更新数据时,所有 Reader 必须等待,直到更新完成
    • 多个 Reader 可同时读数据,不会产生冲突
    • Writer 需要等待所有 Reader 数据读取完毕,才能更新数据

2.1 互斥关系分析

  • Writer 与所有 Reader 在目标数据上读写互斥
  • Reader 之间不存在目标数据的读互斥(整体)
  • Reader 之间存在同时读写其它数据的互斥关系

2.2 多任务读写问题模型

在这里插入图片描述

2.3 注意

一个 Writer 和多个 Reader 之间 通过g_mutex_write互斥,使得写权限互斥锁的所有权(g_mutex_write)可以在多个 Reader 之间传递。

在这里插入图片描述

会出现问题:ReaderA获取锁,ReaderB释放锁

2.4 扩展互斥锁的类型

  • Normal
    • 简单互斥锁,不支持多次获取锁
    • 获取锁和释放锁的任务可以不同
  • Strict
    • 严格互斥锁,支持多次获取锁
    • 获取锁和释放锁的任务必须是同一个

2.5 编程实验:多任务读写示例

【参看链接】:66 - 进程互斥锁的应用示例 / 01多任务读写问题

在这里插入图片描述

2.6 思考

  • 如何使用互斥锁解决“吃饭问题”?
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

uuxiang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值