操作系统疑惑——吸烟者问题

本文通过具体代码示例,探讨了使用PV操作解决经典抽烟问题的方法,并针对代码中出现的疑惑进行了讨论,如如何实现三个吸烟者的互斥等问题。

直接上代码


int random;
semaphore offer1 = 0;// 定义信号量对应的组合1
semaphore offer2 = 0;// 定义信号量对应的组合2
semaphore offer3 = 0;// 定义信号量对应的组合3
semaphore finish = 0;// 定义信号量表示抽烟是否完成

process P1() {// 生产者进程
    while(1) {
        random = 随机整形数;
        random = random%3;
        if(random == 0)
            V(offer1);
        else if(random == 1)
            V(offer2);
        else
            V(offer3);
        任意两种材料放在桌子上;
        P(finish);// 此处用P干嘛?P的目的不是请求资源吗,此处不该是提供资源吗?
    }
}

process P2() {
    while(1) {
        P(offer3);
        拿组合3对应的材料,卷烟,吸烟;
        V(finish);// 继续懵逼,此处用V干嘛?如何阻止3个吸烟者的互斥?
    }
}
process P3() {
    while(1) {
        P(offer2);
        拿组合2对应的材料,卷烟,吸烟;
        V(finish);// 继续懵逼,此处用V干嘛?如何阻止3个吸烟者的互斥?
    }
}
process P4() {
    while(1) {
        P(offer1);
        拿组合1对应的材料,卷烟,吸烟;
        V(finish);// 继续懵逼,此处用V干嘛?如何阻止3个吸烟者的互斥?
    }
}

疑惑:该算法如何用PV操作进行3个吸烟者的互斥的??

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值