操作系统--信号量经典同步问题之写者优先问题

本文介绍了操作系统中写者优先的同步问题,包括两种情况的伪代码实现。第一种情况确保写者线程优先于读者线程,但不支持写者抢占;第二种情况通过增加信号量y实现了写者线程对已进入临界区的读者线程的抢占。
摘要由CSDN通过智能技术生成

写者优先比读者优先要复杂一些,写者优先有以下两个内涵:

1. 当写者线程获得临界区的访问权限时, 其他写者线程不要需要要优先于读者线程获得临界区的访问权限,只有当所有的写者线程都执行后,读者线程才能获得权限。

2. 当读者线程获得临界区的访问权限时,写者线程可以实现抢占,即写者线程优先于其他等待的读者线程,只有当所有的写者线程都执行后,读者线程才能获得权限。


有的参考书中对写者优先的定义仅限于上述第一条。有的定义需满足上述两条。下面分别用伪代码实现这两种情况。


int WriteCount=0, ReadCount=0// 共享变量

semaphore WriteMutex=1, ReadMutex=1, x=1,y=1;

void reader()
{

while(1)

{

sem_wait( ReadMutex);

sem_wait(x); // 保证原子操作

++ReadCount;

if(ReadCount ==1)

sem_wait(WriteMutex); //当有读者线程时应避免同时有写者线程进行写操作。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值