大家好!今天让小编来大家介绍下关于哲学家就餐问题解决方案(哲学家就餐问题)的问题,以下是小编对此问题的归纳整理,让我们一起来看看吧。

哲学家就餐问题解决方案(哲学家就餐问题)  第1张

您好,今天芳芳来为大家解答以上的问题。哲学家就餐问题解决方案,哲学家就餐问题相信很多小伙伴还不知道,现在让我们一起来看看吧!

1、两个地方应该是pv操作,pv都是操作元语,不可中断p操作是将信号量1v操作是将信号量+1pv一定要配对使用哲学家进餐可以通过信号量机制解决。

2、避免死锁注释如下:Void test(int i) //测试哲学家i是否满足eating条件{ if(state[i]==HUNGRY) //状态为hungry且左右均未在eating状态,即筷子空闲 && (state[(i1)%5]!=EATING) &&(state[(i+1)%5]!=EATING) { state[i]=EATING; //设置哲学家i的状态标志为eating V(&s[i]);(不懂,什么意思) //s[i]初始化为0。

3、表示能否eating的信号量,V之后s[i]=1,可以 } //通过P操作后进入eating。

4、否则在P(s[i])处阻塞}state[i]=THINKING; //初始化状态位s[i]=0; //初始化s[i] 信号量Void philosopher(int i){ while (true) { 思考; P(mutex);(还有这个地方也不太懂) //对mutex进行P操作,即加锁,防止过 //多进程同时执行造成死锁 state[i]=HUNGRY; //设置i状态 test (i); //测试是否可以进eating。

5、如可以,设置 //相应标志位和信号量 V(mutex); //释放信号量,其它进程可执行P(mutex) P(s[i]); //测试是否可以eating //以下为哲学家i的eating过程 拿左筷子; 拿右筷子; 进食; 放右筷子; 放左筷子;} P(mutex); //对mutex加锁。

6、防止多个进程同时对state[i]操作 state[i]=THINKING; //设置i状态 test([i1]%5); //为左边和右边测试并设置s状态 test([i+1]%5); V(mutex); //释放信号量}。

本文就为大家分享到这里,希望小伙伴们会喜欢。

以上就是小编对于哲学家就餐问题解决方案(哲学家就餐问题)问题和相关问题的解答了,哲学家就餐问题解决方案(哲学家就餐问题)的问题希望对你有用!