麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Java > 正文

哲學家就餐問題中的JAVA多線程學習

2019-11-26 15:53:26
字體:
供稿:網(wǎng)友

問題描述:一圓桌前坐著5位哲學家,兩個人中間有一只筷子,桌子中央有面條。哲學家思考問題,當餓了的時候拿起左右兩只筷子吃飯,必須拿到兩只筷子才能吃飯。上述問題會產(chǎn)生死鎖的情況,當5個哲學家都拿起自己右手邊的筷子,準備拿左手邊的筷子時產(chǎn)生死鎖現(xiàn)象。

解決辦法:

1、添加一個服務(wù)生,只有當經(jīng)過服務(wù)生同意之后才能拿筷子,服務(wù)生負責避免死鎖發(fā)生。

2、每個哲學家必須確定自己左右手的筷子都可用的時候,才能同時拿起兩只筷子進餐,吃完之后同時放下兩只筷子。

3、規(guī)定每個哲學家拿筷子時必須拿序號小的那只,這樣最后一位未拿到筷子的哲學家只剩下序號大的那只筷子,不能拿起,剩下的這只筷子就可以被其他哲學家使用,避免了死鎖。這種情況不能很好的利用資源。 

代碼實現(xiàn):實現(xiàn)第2種方案

復制代碼 代碼如下:

package cn.edu.sdust.Philosopher;


/*每個哲學家相當于一個線程*/
class Philosopher extends Thread{
    private String name;
    private Fork fork;
    public Philosopher(String name,Fork fork){
        super(name);
        this.name=name;
        this.fork=fork;
    }

    public void run(){
        while(true){
            thinking();
            fork.takeFork();
            eating();
            fork.putFork();
        }

    }

   
    public void eating(){
        System.out.println("I am Eating:"+name);
        try {
            sleep(1000);//模擬吃飯,占用一段時間資源
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

   
    public void thinking(){
        System.out.println("I am Thinking:"+name);
        try {
            sleep(1000);//模擬思考
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}

class Fork{
    /*5只筷子,初始為都未被用*/
    private boolean[] used={false,false,false,false,false,false};

    /*只有當左右手的筷子都未被使用時,才允許獲取筷子,且必須同時獲取左右手筷子*/
    public synchronized void takeFork(){
        String name = Thread.currentThread().getName();
        int i = Integer.parseInt(name);
        while(used[i]||used[(i+1)%5]){
            try {
                wait();//如果左右手有一只正被使用,等待
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
        used[i ]= true;
        used[(i+1)%5]=true;
    }

    /*必須同時釋放左右手的筷子*/
    public synchronized void putFork(){
        String name = Thread.currentThread().getName();
        int i = Integer.parseInt(name);

        used[i ]= false;
        used[(i+1)%5]=false;
        notifyAll();//喚醒其他線程
    }
}

//測試
public class ThreadTest {

    public static void main(String []args){
        Fork fork = new Fork();
        new Philosopher("0",fork).start();
        new Philosopher("1",fork).start();
        new Philosopher("2",fork).start();
        new Philosopher("3",fork).start();
        new Philosopher("4",fork).start();
    }
}

運行結(jié)果:

復制代碼 代碼如下:

I am Thinking:0
I am Thinking:2
I am Thinking:3
I am Thinking:1
I am Thinking:4
I am Eating:0
I am Eating:2
I am Thinking:0
I am Eating:4
I am Thinking:2
I am Eating:1
I am Thinking:4
I am Eating:3
I am Thinking:1
I am Eating:0
I am Thinking:3
I am Eating:2
I am Thinking:0
I am Eating:4
I am Thinking:2

分析:上述解決方案解決了死鎖問題。可以看到最多只能有兩條相鄰的eating結(jié)果,因為每個時刻最多能夠滿足兩個人同時進餐,且兩人座位不相鄰。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 精品不卡| 成人午夜精品久久久久久久蜜臀 | av电影免费在线看 | 婷婷中文字幕一区二区三区 | 国产精品免费久久久久久 | 91网站链接 | 亚洲福利视频52 | 久久精品视频2 | 久久成人免费观看 | 182tv成人福利视频免费看 | 密室逃脱第一季免费观看完整在线 | 高清视频91 | 污黄视频在线播放 | 国产精品久久久久久模特 | 亚洲综合网站 | 午夜视频在线观看免费视频 | 色天使中文字幕 | 精品久久久久久久久久久久久久久久久久久 | 91小视频在线观看免费版高清 | 7777视频| 亚洲福利在线观看视频 | 国产精品午夜在线观看 | 老师你怎么会在这第2季出现 | 蜜桃传免费看片www 一本色道精品久久一区二区三区 | av在线浏览 | 欧美精品99 | 激情免费视频 | 免费国产成人高清在线看软件 | 做爰xxxⅹ性护士hd在线 | 欧美 国产 亚洲 卡通 综合 | 黄色高清视频网站 | 黄色网址在线免费 | 视频一区二区国产 | 欧美一级精品 | 国产精品剧情一区二区三区 | 55夜色66夜色国产精品视频 | 4p嗯啊巨肉寝室调教男男视频 | 成人毛片视频在线观看 | 黑人一级片 | 成人免费在线观看视频 | 国产精品一区二区三区在线播放 |