PV原语操作,操作系统题

有进程P1和P2共享变量Q,这两个进程对变量Q的操作是互斥的,以下是两个进程的程序段:其中信号灯S的初值为1,Q的初值为0。假设P2正在执行PRINTF(“Q=\n0/0... 有进程P1和P2共享变量Q,这两个进程对变量Q的操作是互斥的,以下是两个进程的程序段:其中信号灯S的初值为1,Q的初值为0。假设P2正在执行PRINTF(“Q=\n0/0d”,Q)语句时,P1也被调度执行。试给出P1执行完成后的打印结果和变量Q的值。
P1() p2()
{…; {…;
p(S); P(S);
Q++; PRINTF(“Q=\n0/0d”,Q);
V(S); Q=0;
…; V(S);
} …;
}

哪个答案正确?大体说明一下原理
⑴、打印结果:Q=1 ⑵:变量Q的值:0
⑴、打印结果:Q=0 ⑵:变量Q的值:1
PRINTF(“Q=\n0/0d”,Q);什么意思?
展开
 我来答
匿名用户
2013-04-20
展开全部
PRINTF(“Q=\n0/0d”,Q;

伪代码, 就是用来描述的, 你就理解为此处要输出Q的值呗.

答案是

打印结果 Q=0, 变量Q值为1
因为前提是假设P2已经执行到printf语句了, 之前已经用P申请到了信号灯S, 由于S初值为1, P(S)后值为0,

此时P1开始调度, 执行到P(S)时,
如果p2还未执行到V(S) , 那么由于S值为0, 信号灯还未释放, 所以P1 会等待P2 执行完V(S)释放信号灯后才继续执行,

所以, 在p1开始调度时, p2已经完成P(S)的背景下,
打印的结果是Q=0, p1执行完Q的值是1
Sievers分析仪
2025-04-08 广告
是的。传统上,对于符合要求的内毒素检测,最终用户必须从标准内毒素库存瓶中构建至少一式两份三点标准曲线;必须有重复的阴性控制;每个样品和PPC必须一式两份。有了Sievers Eclipse内毒素检测仪,这些步骤可以通过使用预嵌入的内毒素标准... 点击进入详情页
本回答由Sievers分析仪提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式