亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

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

2019-11-26 15:53:26
字體:
來源:轉載
供稿:網友

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

解決辦法:

1、添加一個服務生,只有當經過服務生同意之后才能拿筷子,服務生負責避免死鎖發生。

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

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

代碼實現:實現第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();
    }
}

運行結果:

復制代碼 代碼如下:

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結果,因為每個時刻最多能夠滿足兩個人同時進餐,且兩人座位不相鄰。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品免费av| 久久久亚洲欧洲日产国码aⅴ| 97视频网站入口| 亚洲在线观看视频网站| 91久热免费在线视频| 日韩精品中文字幕有码专区| 欧美激情videos| 51精品在线观看| 欧美一级片在线播放| 在线视频欧美性高潮| 午夜精品久久久久久久白皮肤| 91在线精品视频| 欧美激情国产日韩精品一区18| 中文字幕日韩综合av| 91精品久久久久久久久| 色阁综合伊人av| 92版电视剧仙鹤神针在线观看| 日本一本a高清免费不卡| 欧美成人中文字幕在线| 亚洲欧美综合精品久久成人| 亚洲国产一区二区三区在线观看| 中文字幕日韩精品有码视频| 亚洲日韩欧美视频一区| 国产美女主播一区| 中文字幕日韩av综合精品| 亚洲人成电影网站色www| 国产精品96久久久久久又黄又硬| 国产精品影片在线观看| 国产成人精品视| 日韩成人在线视频观看| 久色乳综合思思在线视频| 久久久久久com| 成人免费直播live| 亚洲欧美一区二区三区四区| 久久久久一本一区二区青青蜜月| 欧美亚洲视频在线看网址| www.亚洲一二| 一区二区三区www| www高清在线视频日韩欧美| 久久精品国产91精品亚洲| 中文字幕视频在线免费欧美日韩综合在线看| 91精品视频在线免费观看| 亚洲天堂一区二区三区| 亚洲成色999久久网站| 在线视频精品一| 久久精品国产欧美激情| 欧美性xxxx在线播放| 欧美超级免费视 在线| 色诱女教师一区二区三区| 亚洲美女视频网| 一区二区三区美女xx视频| 精品久久久999| 久久免费视频观看| 欧美日韩国产一区在线| 狠狠做深爱婷婷久久综合一区| 欧美寡妇偷汉性猛交| 国产视频精品在线| 在线观看欧美视频| 亚洲一区二区少妇| 国产亚洲精品激情久久| 欧美最猛黑人xxxx黑人猛叫黄| 在线观看亚洲区| 亚洲精品国产精品久久清纯直播| 国产视频自拍一区| 成人免费淫片aa视频免费| 亚洲一级黄色av| 日韩性xxxx爱| 国产精品电影在线观看| 日韩中文在线观看| 国产精品人成电影| 欧美日韩一区二区免费在线观看| 欧美日韩xxxxx| 91久久精品国产91久久性色| 亚洲国产日韩欧美在线图片| 欧美情侣性视频| 欧美午夜性色大片在线观看| 精品国产一区二区三区久久狼5月| 亚洲有声小说3d| 欧美日韩国产影院| 亚洲欧美日韩精品久久奇米色影视| 97色在线观看免费视频| 国产精品91在线观看| 日本精品一区二区三区在线| 亚洲а∨天堂久久精品9966| 中文字幕亚洲综合久久筱田步美| 亚洲欧美日本伦理| 91精品视频在线看| 亚洲欧美激情在线视频| 欧美另类69精品久久久久9999| 68精品国产免费久久久久久婷婷| 国产www精品| 国产日韩专区在线| 亚洲成人激情视频| 欧美日韩一区二区免费视频| 亚洲精品欧美日韩专区| 欧美黑人极品猛少妇色xxxxx| 欧美影院在线播放| 另类视频在线观看| 亚洲一二三在线| 日韩精品视频免费专区在线播放| 国产精品夜色7777狼人| 亚洲在线观看视频| 国产成人精品一区二区三区| 97在线精品视频| 国语自产精品视频在线看抢先版图片| 亚洲一区二区中文字幕| 国产中文字幕91| 国产乱肥老妇国产一区二| 91麻豆国产精品| 色777狠狠综合秋免鲁丝| 538国产精品一区二区在线| 深夜福利亚洲导航| 91精品国产综合久久久久久蜜臀| 国产精品自拍网| 国产精品久久色| 久久亚洲精品国产亚洲老地址| 欧美电影免费观看高清完整| 欧美理论电影在线观看| 中文字幕国产亚洲2019| 色诱女教师一区二区三区| 国产精品久久久久久亚洲调教| 色妞一区二区三区| 亚洲天堂av图片| 欧美日韩美女在线观看| 亚洲国产美女精品久久久久∴| 色久欧美在线视频观看| 精品久久久久久中文字幕大豆网| 精品成人乱色一区二区| 久久久亚洲精选| 亚洲自拍偷拍区| 午夜美女久久久久爽久久| 久久韩国免费视频| 国产精品极品美女在线观看免费| 亚洲精品美女在线| 免费91麻豆精品国产自产在线观看| 亚洲欧美中文日韩在线v日本| 久久久久亚洲精品国产| 91高清视频免费观看| 亚洲无亚洲人成网站77777| 久久精品色欧美aⅴ一区二区| 欧美激情在线观看| 久久夜精品va视频免费观看| 国产91精品久久久久| 精品国产精品三级精品av网址| 亚洲深夜福利视频| 一本色道久久88综合亚洲精品ⅰ| 一本色道久久88精品综合| 色午夜这里只有精品| 日韩经典中文字幕在线观看| 国产成人精品免高潮在线观看| 亚洲精品一区二区网址| 亚洲第一综合天堂另类专| 亚洲女人被黑人巨大进入| 精品精品国产国产自在线| 欧美激情影音先锋| 久久精品国产一区二区电影| 国产亚洲成av人片在线观看桃| 国产精品视频久久久久| 国产精品视频久久久| 精品国产31久久久久久| 一区二区福利视频| 韩国精品美女www爽爽爽视频| 国产精品美女在线| 欧美日韩中文字幕日韩欧美|