操作系统:哲学家进餐问题
生活随笔
收集整理的這篇文章主要介紹了
操作系统:哲学家进餐问题
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
哲學家進餐問題
?
五個哲學家圍著一張圓桌,每個哲學家面前放著食物。哲學家的生活有兩種交替活動:吃飯以及思考。當一個哲學家吃飯時,需要先拿起自己左右兩邊的兩根筷子,并且一次只能拿起一根筷子。
下面是一種錯誤的解法,考慮到如果所有哲學家同時拿起左手邊的筷子,那么就無法拿起右手邊的筷子,造成死鎖。
#define N 5void philosopher(int i) {while(TRUE) {think();take(i); // 拿起左邊的筷子take((i+1)%N); // 拿起右邊的筷子eat();put(i);put((i+1)%N);} }為了防止死鎖的發生,可以設置兩個條件:
- 必須同時拿起左右兩根筷子;
- 只有在兩個鄰居都沒有進餐的情況下才允許進餐。
總結
以上是生活随笔為你收集整理的操作系统:哲学家进餐问题的全部內容,希望文章能夠幫你解決所遇到的問題。