2 baniel01 Baniel01 于 2013.09.09 10:37 提问

有关操作系统PV原语的问题

在操作系统中有PV原语对进程同步和互斥进行管理,现在假如有三个进程A,B,C,而他们所需的资源系统只有一个,现在A进程运行,他会使用P原语使资源数减一成为0,这时B进程也在申请所以他会被阻塞,这时的资源数为-1,表示有一个进程被阻塞,这时又有C进程申请,他也会被阻塞,也会将资源数减一成为-2。请问这时如果A进程释放该资源,使资源数成为-1,那么这时B进程会由调度成为就绪态,但是操作系统怎么知道这时的资源数-1是什么意思呢?这时的-1是表示有一个进程被阻塞吗?那么这时的资源数又怎么表示啊???

1个回答

q993839535
q993839535   2013.12.26 21:17
已采纳

这里不是根据-1,-2或者负几来判断来调用被阻塞的进程的,而是只要小于0就回去调用阻塞队列里的第一个进程。-1就代表一个进程阻塞,-2代表2个进程阻塞。而资源数的问题,你一开始不就说累了资源系统只有一个吗。你一开始设的初始值1代表着资源数是1,后面那个变量就和资源数没关系了。

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!