999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

利用管程概念求解哲學家進餐問題

2015-03-25 13:22:54詹勁松
長春大學學報 2015年12期
關鍵詞:進程概念

詹勁松

(福建師范大學福清分校 電子與信息工程學院,福建 福清350300)

0 引言

哲學家進餐問題是操作系統中經典的同步問題,它需要在多個進程或線程之間分配多個資源,使進程(線程)能向前推進。我們的目的是要在這種情況下采用某種策略,預防死鎖的發生。管程是一種高級的同步構造,利用Java 高級別并發對象可以實現管程概念。通過管程可以方便地實現這種死鎖預防策略。

1 哲學家進餐問題

5 位哲學家圍坐在一張圓桌旁邊,圓桌中央放置一碗米飯,每兩人之間放置一支筷子。每位哲學家思考、饑餓,然后吃飯。為了吃飯,他必須拿起與他相鄰的左、右兩支筷子。他不能從別的哲學家手里搶奪筷子。吃完飯后,他會放下筷子,并又開始思考。

如果對每個哲學家的吃飯過程不加限制,很快就進入這樣一個狀態,每人搶得一支筷子,結果誰也吃不了飯,也就是進入了死鎖的狀態。產生死鎖有4 個必要條件,互斥、占有并等待、非搶占和循環等待[1]。如果能夠使一組進程(線程)在推進的整個過程中,這4 個條件之一或更多保持不成立,那么這組進程(線程)就不會陷入死鎖狀態。哲學家問題的死鎖預防有多種方法。其中一種是:每位哲學家要能取到手邊的兩支筷子才開始吃飯,否則他一支筷子也不取。這種解法的實質是預先分配需要的全部資源,從而破壞產生死鎖的占有并等待這個必要條件。本文就是采用這種解法。

2 管程

為了解決同步問題程序中使用信號量容易出錯的問題,70 年代初,P.B.Hansen 和C.A.R.Hoare 等人提出了管程的概念。其基本思想是:把分散于各進程(線程)中的臨界區集中起來統一管理,并把共享資源用數據結構來抽象表示,建立一個管程結構來管理相應的訪問[2]。管程結構確保一次只能有一個進程(線程)在管程內活動。

管程結構通過防止對一個資源的并發訪問來達到了實現臨界區的目的,從而提供了實現互斥的手段,但是管程并沒有提供進程(線程)和其他進程(線程)之間同步的途徑。當一個進程(線程)進入了管程并調用了管程的一個過程。如果該過程在執行時發現資源不能得到滿足,當然應該讓此進程(線程)阻塞,同時需要開放管程,讓之前被阻擋在管程外邊的進程(線程)之一進入。為此需要定義一個另外的同步機制,這可由條件(Condition)結構來提供。條件變量只有操作wait()和signal()。前者用于阻塞調用的進程(線程)。后者用于啟動一個被阻塞的進程(線程)。

3 Java 高級別并發對象

在Java SE 5.0 之前,用Java 實現管程有些不精確。因為線程之間的同步只能使用Object 類的wait(),和notify()或notifyAll()來實現。只能向任何一個被阻塞線程或者全部被阻塞線程發送啟動消息,不能準確定位向某一個被阻塞線程發送消息。Java SE 5.0 引入了ReentrantLock 類和Condition 接口[3],改變了這個狀況。通過調用Condtiton 對象的signal 方法,某個哲學家吃完飯,放下筷子就可以準確地向其相鄰的兩位哲學家線程發出啟動信號。

4 算法描述

借助信號量,算法描述如下:

其Java 實現代碼:

以Monitor1 類實現管程概念,內含pickup、putdown 兩個方法,供哲學家線程對象調用。這兩個方法是互斥的,確保一次只能有一個哲學家線程在管程內活動。運用管程概念,哲學家線程運行過程編程十分簡單。只要調用管程相應的方法,就能夠保證線程之間的互斥和同步。

我們在四核i5 CPU,4G 內存的計算機,Windows7 平臺上運行該程序4 個小時沒有發生死鎖和也沒有發生餓死。5 個哲學家線程進入吃飯狀態的幾率差不多。

5 結語

本文利用Java 高級別對象和管程概念給出了哲學家進餐問題死鎖預防的一種解法。與文獻4 中的方法相比[4],借助管程概念求解哲學家進餐問題,把所有的互斥、同步相關代碼集中在于管程類內,在更高的層次上解決問題,使代碼不容易出錯,可讀性更好,并且程序模塊化的程度更高。

[1] Abraham Silbertschatz,Peter Baer Galvin,Geg Gagne.操作系統概念[M].鄭扣根,譯.7 版.北京:高等教育出版社,2010.

[2] 費翔林,駱斌.操作系統教程[M].5 版。北京:高等教育出版社,2014.

[3] CayS.Horstmann,Gary Cornell.Java 核心技術卷1[M].周立新,陳波,葉乃文,等譯.北京:機械工業出版社,2013.

[4] 詹勁松.利用Java 高級別并發對象求解哲學家進餐問題[J].佳木斯大學學報(自然科學版),2013,31(6):905-906.

猜你喜歡
進程概念
Birdie Cup Coffee豐盛里概念店
現代裝飾(2022年1期)2022-04-19 13:47:32
幾樣概念店
現代裝飾(2020年2期)2020-03-03 13:37:44
債券市場對外開放的進程與展望
中國外匯(2019年20期)2019-11-25 09:54:58
學習集合概念『四步走』
聚焦集合的概念及應用
論間接正犯概念之消解
概念的限制
我國高等教育改革進程與反思
教育與職業(2014年7期)2014-01-21 02:35:04
Linux僵死進程的產生與避免
男女平等進程中出現的新矛盾和新問題
主站蜘蛛池模板: 五月激情婷婷综合| 69av在线| 91系列在线观看| 亚洲国产成人麻豆精品| 美女扒开下面流白浆在线试听 | 一级香蕉视频在线观看| 久久精品无码专区免费| 国产网友愉拍精品视频| 中文字幕亚洲乱码熟女1区2区| 午夜a级毛片| 伊人久久大香线蕉aⅴ色| 国产综合无码一区二区色蜜蜜| 亚洲成aⅴ人在线观看| 国产黄网永久免费| 国产91无码福利在线| 亚洲精品视频在线观看视频| 夜夜操国产| 在线视频亚洲色图| 亚洲视频在线青青| 午夜精品一区二区蜜桃| 亚洲最大情网站在线观看| 日韩美一区二区| 国产精品专区第1页| 欧美精品一区在线看| 狠狠色丁婷婷综合久久| 国产精品无码AV中文| 色久综合在线| 欧美亚洲欧美区| 久久综合久久鬼| 国产精品女在线观看| 99精品伊人久久久大香线蕉| 一本视频精品中文字幕| 亚洲日韩久久综合中文字幕| 99久久免费精品特色大片| 中文字幕人成人乱码亚洲电影| 亚洲国产成熟视频在线多多| 99ri精品视频在线观看播放| 欧美亚洲第一页| 啦啦啦网站在线观看a毛片| 精品国产Av电影无码久久久| 少妇人妻无码首页| 91在线精品麻豆欧美在线| 国产AV无码专区亚洲精品网站| 不卡无码h在线观看| 国产青榴视频在线观看网站| 国产成人AV综合久久| 日韩成人高清无码| 国产成人AV综合久久| 无码日韩视频| 色综合网址| 一级毛片a女人刺激视频免费| 亚洲婷婷在线视频| 青草91视频免费观看| 亚洲最黄视频| a级毛片视频免费观看| 美女潮喷出白浆在线观看视频| 性喷潮久久久久久久久| 亚洲精品第一页不卡| 亚洲第一页在线观看| 国产玖玖视频| 欧美精品成人| 精品人妻无码中字系列| 色综合激情网| 99久久99这里只有免费的精品| 国产一区在线视频观看| 欧美另类一区| 国产特级毛片| 全午夜免费一级毛片| 国产精品开放后亚洲| 久久永久精品免费视频| 性视频久久| 日本高清有码人妻| 国产精品30p| 日韩激情成人| 人妻丝袜无码视频| 精品人妻AV区| 亚洲AV无码一区二区三区牲色| 久久精品这里只有国产中文精品| www.91中文字幕| 伊人激情久久综合中文字幕| 日韩亚洲综合在线| 精品国产成人三级在线观看|