经典进程同步与互斥问题

经典进程同步与互斥问题

一、生产者与消费者问题

1.1 问题概述

  • 生产者与消费者互斥使用一个缓冲池
  • 当缓冲池为空时,生产者才能写入数据
  • 当缓冲池不为空时,消费者才能读取数据

1.2 解决方法

设置3个信号量:mutex=1,full=0,empty=n(假设缓冲池大小为n)

  • mutex:互斥信号量
  • full:表达缓冲池中数据量的信号量,初值为0
  • empty:表达缓冲池中空闲块的信号量,初值为n,即缓冲池的大小
  • 生产者
P(empty)
P(mutex)
写入数据
V(mutex)
V(full)
  • 消费者
P(full)
P(mutex)
读取数据
V(mutex)
V(empty)

二、读者与写者问题

2.1 问题概述

一个数据对象(如文件、记录)可以被多个进程共享。这些进程可以分为两类:

  • 读者进程:只读取数据对象的值
  • 写者进程:修改或者写入数据对象的值

这类问题具有以下特点:

  1. 读者进程之间不互斥
  2. 写者与写者、写者与读者之间互斥

2.2 解决方法

设置3个信号量࿱

  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值