吸烟者问题
2020/10/08 20:09
问题
吸烟者问题。三个吸烟者在一个房间内,还有一个香烟供应者。 为了制造并抽掉香烟,每个吸烟者需要三样东西:烟草、纸和火柴,供应者有丰富货物提供。三个吸烟者中,第一个有自己的烟草,第二个有自己的纸,第三个有自己的火柴。 供应者随机地将两样不同的东西放在桌子上,允许一个吸烟者进行对健康不利的吸烟。当吸烟者完成吸烟后唤醒供应者,供应者再随机地把两样不同的东西放在桌子上,唤醒一个吸烟者。 试用信号量的P、V操作设计该问题的同步算法,给出所用共享变量(如果需要)和信号量及其初始值,并说明各自的含义。
代码
semaphore F
=0;
semaphore tobacco
= 0;
semaphore paper
= 0;
semaphore match
= 0;
int i
= 0, j
= 0;
int k
;
provider()
{
P(F
);
while (true)
{
i
= rand() % 3;
j
= rand() % 3;
if (i
!= j
)
{
break;
}
}
if (i
== 0 || j
== 0)
{
V(tobacco
);
}
if (i
== 1 || j
== 1)
{
V(paper
);
}
if (i
== 2 || j
== 2)
{
V(match
);
}
put();
}
smoker()
{
switch (k
)
{
case 1:
{
P(tobacco
)
P(paper
);
break;
}
case 2:
{
P(tobacco
)
P(match
);
break;
}
case 3:
{
P(paper
);
P(match
);
break;
}
}
smoke();
V(F
);
}
是否放东西也是需要互斥的
转载请注明原文地址:https://blackberry.8miu.com/read-44067.html