PV操作读者写者问题

进程互斥、进程同步,信号量

要求:允许几个读者可以同时读该数据集,而一个写者不能与其他进程(不管是读者还是写者)同时访问该数据集。

两类进程:读进程、写进程

互斥关系:读进程-写进程,写进程-写进程(读进程与读进程不存在互斥关系)

semaphore rw=1;//互斥访问数据集的信号量
int count=0;//记录访问数据集的读进程数(用来实现读进程之间不发生互斥)
semaphore mutex=1;//互斥修改count值的信号量

writer(){//写者进程
    while(1){
        P(rw);//相当于加锁(rw=1时说明数据集没有进程访问),rw--
        write;//写操作
        V(rw);//相当于解锁(恢复rw=1),rw++;
  }
}

writer(){//写者进程
    while(1){
        P(rw);//相当于加锁(rw=1时说明数据集没有进程访问),rw--
        write;//写操作
        V(rw);//相当于解锁(恢复rw=1),rw++;
  }
}


reader(){//读者进程
    while(1){
        P(mutex);//在判断count值之前先对count加锁,防止判断之后count被修改
        if(count==0){//先判断是否应该对数据集加锁,如果是第一个读进程(count=0)就要进行加锁;如 
                     //果已经有读进程正在访问数据集(count>0),则跳过加锁直接访问
        P(rw);//对数据集加锁
    }
        count++;//修改count,把自己的进程算进总读进程数
        V(mutex);//修改count后,将修改count的锁解除

        read;//读操作
        
        P(mutex);//在执行完读操作后意味着该进程将要停止访问数据集,就要修改count,同样也要加锁
        count--;//修改count
        if(count==0){//需要判断是否应该对数据集解锁,如果已经没有读进程(count=0)就要进行解锁; 
                     //如果还有读进程正在访问数据集(count>0),则跳过解锁直接退出
        V(rw);//对数据集解锁锁
    }
        V(mutex);//修改count后,将修改count的锁解除
  }
}








  • 7
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
读者写者问题是一个经典的并发控制问题,其中有多个读者和写者同时访问共享资源,但是存在一些限制条件。PV(信号量)是一种常用的同步原语,可以用来解决并发控制问题。在读者写者问题中,可以使用两个信号量来实现同步:一个用于控制读者的访问,另一个用于控制写者的访问。 假设有以下变量: - int readCount: 记录当前正在读取的读者数量 - semaphore mutex: 保护对readCount的访问,确保同一时间只有一个读者或写者访问readCount变量 - semaphore wrt: 用于控制写者的访问 读者的伪代码如下: ``` while true: P(mutex) readCount++ if readCount == 1: P(wrt) V(mutex) // 读取共享资源 P(mutex) readCount-- if readCount == 0: V(wrt) V(mutex) ``` 写者的伪代码如下: ``` while true: P(wrt) // 写入共享资源 V(wrt) ``` 在上述伪代码中,读者在访问共享资源之前会先对mutex信号量进行P操作,以确保同一时间只有一个读者或写者访问readCount变量。读者进入临界区后,会将readCount加1,并检查是否是第一个读者,如果是,则对wrt信号量进行P操作,阻塞写者的访问。读者访问完共享资源后,会将readCount减1,并检查是否是最后一个读者,如果是,则对wrt信号量进行V操作,允许写者的访问。 写者在访问共享资源之前会先对wrt信号量进行P操作,以阻塞其他读者和写者的访问。写者完成写入操作后,会对wrt信号量进行V操作,允许其他读者和写者的访问。 通过使用PV(信号量),可以实现对读者写者问题的并发控制,确保共享资源在读者和写者之间正确地同步和互斥访问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值