读者-写者问题

读者-写者问题是数据库访问的模型,允许多个进程读取但仅允许一个进程写入。当读者到来时,它们增加计数器并访问,而写者必须等待所有读者完成。一种解决方案是,当有写者等待时,新的读者会被挂起,直到当前读者完成,但这可能导致写者长时间等待。Courtois提供了写者优先的策略以提高效率。
摘要由CSDN通过智能技术生成

哲学家就餐问题对于互斥访问有限资源的竞争问题(如I/O设备)一类的建模过程十分有用。另一个著名的问题是读者-写者问题(Courtois 等人,1971),它为数据库访问建立了一个模型。例如,设想一个飞机订票系统,其中有许多竞争的进程试图读写其中的数据。多个进程同时读数据库是可以接受的,但如果一个进程正在更新(写)数据库,则所有的其他进程都不能访问该数据库,即使读操作也不行。这里的问题是如何对读者和写者进行编程?图2-47给出了一种解法。

在该解法中,第一个读者对信号量db 执行down操作。随后的读者只是递增一个计数器rc。当读者离开时,它们递减这个计数器,而最后一个读者对信号量执行up,这样就允许一个被阻塞的写者(如果存在的话)可以访问该数据库。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值