吸烟者问题

吸烟者问题

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);//释放资源,桌子可以放东西
	
}

是否放东西也是需要互斥的

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Handsome Wong

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值