操作系統(tǒng)課程設(shè)計 linux系統(tǒng)下實現(xiàn)PV操作_第1頁
操作系統(tǒng)課程設(shè)計 linux系統(tǒng)下實現(xiàn)PV操作_第2頁
操作系統(tǒng)課程設(shè)計 linux系統(tǒng)下實現(xiàn)PV操作_第3頁
操作系統(tǒng)課程設(shè)計 linux系統(tǒng)下實現(xiàn)PV操作_第4頁
操作系統(tǒng)課程設(shè)計 linux系統(tǒng)下實現(xiàn)PV操作_第5頁
已閱讀5頁,還剩17頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、江塚大吟學與通信工程學院操作系統(tǒng)課程設(shè)計報告題目:linux系統(tǒng)下實現(xiàn)PV操作班級軟件工程1401姓名學號: 指導老師:2016年12月27日1 / 19目錄11 / 19、 實驗題目、 實驗目的和要求 三、 環(huán)境配置四、設(shè)計思路五、代碼實現(xiàn)六、總結(jié)17實驗題目1.Linux 系統(tǒng)簡單使用認識 Linux ubuntu 安裝終端的簡單使用4)python3.5.2 源碼安裝2.多線程和多進程同步方法解決水果分配問題:水果分配的問題:桌上有一只盤子,每次只能放入 5 只水果。爸爸專放蘋果, 媽媽專放橘子,一個兒子專等吃盤子中的橘子,一個女兒專等吃盤子中的蘋果.用P, V操作實現(xiàn)爸爸、媽媽、兒子、

2、女兒進程的同步控制。補充 :設(shè)有兩個籃子,分別有若干個蘋果或橘子,爸爸和媽媽將每次從水果籃子中拿出一個水果放入水果盤中, 兒子女兒則挑選各自喜歡 的水果。1)2)分析問題,寫出偽代碼線程實現(xiàn)進程實現(xiàn)實驗目的和要求1. 認識和學會使用 linux 系統(tǒng):Linux是一種可以在PC機上執(zhí)行的類似UNIX的操作系統(tǒng),是一個完全免費的操作系統(tǒng)。1991年,芬蘭學生Linus Torvalds開發(fā)了這個操作系統(tǒng)的核心部分,因為是 Linus 改良的 minix 系統(tǒng),故稱之為 Linux.2. 理解線程和進程的互斥和同步原理:同步是操作系統(tǒng)級別的概念 ,是在多道程序的環(huán)境下, 存在著不同的制約關(guān)系,為了

3、協(xié)調(diào)這種互相制約的關(guān)系,實現(xiàn)資源共享和進程協(xié)作,從而避免 進程之間的沖突,引入了進程同步。進程互斥是間接制約關(guān)系。當一個進程進入臨界區(qū)使用臨界資源時,另一個進程必須等待。只有當使用臨界資源的進程退出臨界區(qū)后,這個進程才 會解除阻塞狀態(tài)。3. 使用信號量和互斥量解決問題:通過設(shè)置一個表示資源個數(shù)的信號量S,通過對信號量S的P和V操作來實現(xiàn)進程的的互斥。通過設(shè)置一個表示資源個數(shù)的信號量S,通過對信號量S的P和V操作來實現(xiàn)進程的的互斥。P和V操作分別來自荷蘭語Passeren和Vrijgeven ,分別表示占有和釋 放。 P V 操作是操作系統(tǒng)的原語,意味著具有原子性。P 操作首先減少信號量,表示有

4、一個進程將占用或等待資源,然后檢測S是否小于0,如果小于0則阻塞,如果大于0則占有資源進行執(zhí)行。V操作是和P操作相反的操作,首先增加信號量,表示占用或等待資源的進程減少了 1個。然后檢測S是否小于0,如果小于0則喚醒等待使用S 資源的其它進程。環(huán)境配置1. 安裝ubuntu1)下載系統(tǒng)鏡像, ubuntu-16.04.1-desktop-amd64.iso制作啟動U盤,使用Ultraiso軟件將系統(tǒng)鏡像寫入U盤 開機進入BIOS界面,從U盤啟動。對磁盤分區(qū),等待安裝結(jié)束。設(shè)置 root 密碼, sudo passwd root 命令后輸入兩遍密碼。2. 熟悉 ubuntu 的使用常用命令:(1

5、)su命令,切換用戶pwd命令,打印當前工作目錄的絕對路徑(6)(7)(8)(9)Is命令,cd命令,mv命令,rm命令,打印當前目錄下的文件切換工作目錄移動文件或目錄刪除文件或目錄shutdown命令,關(guān)閉計算機reboot命令,重啟電腦tar命令,解壓命令3.安裝vim編輯器在終端下運行ap t-get in stall-y vim即可。安裝結(jié)束后,輸入vim命令,顯示如下圖就說明安裝成功:VIw - Vi IMprovedversion T-4-160by Brafl Hooleraar et at.Modf f (t(l by -u, - IL.% JI1 i opflR &QUrca

6、fra exlt()voldvold-pcIFigure 3 python3 安裝結(jié)果四、1.題目分析:father、mather、son、daughter 是四個線程或進程。盤子plate是它們共享的變量,對盤子的操作要互斥。Father 和 daughter 要對 apple 同步。Mother 和 son 要對 orange 同步。2.偽代碼:father:while(True):P(empty)p(mutex) put apple v(mutex) v(apple)mother:while(True):p(empty) p(mutex) put orange v(mutex) v(or

7、ange)son:while(True):p(orange) p(mutex) get orange v(mutex)v(empty)daughter:while(True):p(apple) p(mutex) get apple v(mutex)v(empty)五、代碼實現(xiàn)1. 線程實現(xiàn)(1)原理threading.py 模塊提供了對線程的操作。創(chuàng)建線程 threading.Thread(target, args),target 數(shù), args 是函數(shù)所需的參數(shù)。是要運行的函2)創(chuàng)建信號量 threading.Semaphore(value), value acquire() 信號量 -1

8、,當為 0 時,阻塞當前線程。+1,大于 0,喚醒等待此信號量的一個線程。創(chuàng)建互斥鎖, threading.Lock(), acquire() 變量 定義 list類型的是信號量的初始值。release() 信號量加鎖, release() 解鎖。定義 list類型的apples_basket 存放所有的蘋果 oranges_basket 存放所有的橘子定義 list定義方法plate 當做水果盤,可以放入蘋果和橘子 father , 用于將蘋果放入水果盤,也就是把類型的apples_basket的一個蘋果,放入 plate 列表中。并打印相關(guān)信息。oranges_basketplate 的一

9、個定義方法 mather , 用于將蘋果放入水果盤, 也就是把 的一個橘子,放入 plate 列表中。并打印相關(guān)信息。定義方法 son , 用于從水果盤取出一個橘子,也就是把 橘子,拿出來,并打印相關(guān)信息。定義方法 daughter , 用于從水果盤取出一個蘋果,也就是把 plate 的 一個蘋果,拿出來,并打印相關(guān)信息。代碼import randomimport threadingimport timeempty = threading.Semaphore(5) # 盤子的容量apple = threading.Semaphore(0) # 同步蘋果的信號量 orange = threadi

10、ng.Semaphore(0) # 同步橘子的信號量mutex = threading.Event() # 表示四個 進程互斥的 訪問盤 子plate = list() # 模擬 水果 盤lock = threadi ng丄ock() # p late 互斥 鎖mutex.set() # 設(shè)置為 Truedef father(basket):global empty, mutex, lock, applewhile len(basket) != 0: # 當蘋果 籃子中沒有蘋果, 則終止# 1.p(empty)empty.acquire() # 將容量 empty 減去 1# 2.p(mute

11、x) mutex.clearO # mutex設(shè)置為False其它線程將等待 # 3.put appleif lock.acquire():temp = basket.pop() plate.append(temp) # 從蘋果 籃子里拿出一個蘋果放入水果 盤print(-father put an apple(0) into plate.format(temp) print( current plate = , plate)lock.release()# 4.v(mutex)mutex.set() # mutex設(shè)置為True, 其它線程可以使用# 5.v(apple) apple.rele

12、ase() time.sleep(random.random() def mother(basket): global empty, mutex, lock, orangewhile len(basket) != 0: # 當橘子 籃子中沒有橘子, 則終止# 1.p(empty)empty.acquireO # 將容量 empty 減去 1# 2.p(mutex) mutex.clearO # mutex設(shè)置為False其它線程將等待# 3.put(orange)if lock.acquire(): temp = basket.pop() plate.append(temp)print(-mo

13、ther put an orange(0) into plate.format(temp)print( current plate = , plate)lock.release()# 4.v(mutex)mutex.set() # mutex 設(shè)置 為 True, 其它 線程可以使用# 5.v(orange) orange.release() time.sleep(random.random() def son(count):global empty, mutex, lock, orange for i in range(count):# 1.p(orange)orange.acquire()

14、 # orange -1# 2.p(mutex) mutex.clear() # mutex 設(shè)置 為 False 其它 線 程將等待# 3.get orangeif lock.acquire():for fruit in plate:if fruit.startswith(Orange): temp = fruit plate.remove(fruit) breakprint(-son take an orange(0) from plate.format(temp)print( current plate = , plate) lock.release()# 4.v(mutex) mute

15、x.set() # mutex 設(shè)置 為 True, 其它 線程可以使用# 5.v(empty)empty.release() # 將 empty + 1 time.sleep(random.random() def daughter(count):global empty, mutex, lock, applefor i in range(count):# 1.p(apple)apple.acquire() # apple -1# 2.p(mutex) mutex.clear() # mutex 設(shè)置 為 False 其它 線 程將等待# 3.get apple if lock.acquir

16、e():for fruit in plate:if fruit.startswith(Apple): temp = fruit plate.remove(fruit) breakprint(-daughter take an apple(0) from plate.format(temp)print( current plate = , plate) lock.release()# 4.v(mutex) mutex.set() # mutex 設(shè)置 為 True, 其它 線程可以使用# 5.v(empty)empty.release() # 將 empty + 1 time.sleep(ran

17、dom.random()if _name_ = _main_:# 初始化蘋果和橘子的個數(shù)apples_basket = Apple-A, Apple-B, Apple-C, Apple-D #模擬蘋果籃子,一共有 4 個蘋果要放入水果 盤oranges_basket = Orange-A, Orange-B, Orange-C # 模擬橘子籃子,一共有 3 個橘子要放入水果 盤# 創(chuàng)建 4 個線程father = threading.Thread(name=Father, target=father,args=(apples_basket, ) # father 線程mother = thre

18、ading.Thread(name=Mother, target=mother,args=(oranges_basket, ) # mother 線 程son = threading.Thread(name=Son, target=son,args=(len(oranges_basket), ) # son 線程daughter = threading.Thread(name=Daughter, target=daughter,args=(len(apples_basket), ) # daughter 線程# 啟動線 程daughter.start() son.start() father.

19、start()mother.startO(4)結(jié)果 A 自 voi devoid-pc; /MyCode/BasicTest-Python/osdesignvot(Jvol(J-pc:-/*iyCod*e/B3str-it*pyhcn/os_;iesti;- Is natnprocesspy nain threod.pyvoldOvold-pt: 燈日 Fi Lzt -Pthnn/os_dpip ythons ma tn-thread. py“father put an current pistematn 22312 -?inother put an 匚urrent plate -daught

20、er take current plateappleCAppLc D) into plate. =ftpple-DorangeOrange-C) Into plate. -Apple-D, orange-c an apple(AppLe-D) fron plate -orangCi:tkc an orangc Into plate.cur rent piste =Orang?ft-rather pur an appleCAppke匚J into plate, current plate -OrengeB, Apple-C-son take an orangeorangCB) from plat

21、e* 二Apple-C an appleApple-c) fron plate =fcurrent plate -daugtiter take current plate -inother put nn current plate -father put sn current plate daughter take current plateorngporringp-A) Inro pl確re.-f Orange A appletAppl?ft) into plate.-Orange-A,Jan apple(Apple-B) fron plate -orange-AASon take an o

22、ronflcdaughter take an apple(Apple A) fron platecurrent plate =votdgvot(li-pc:/4yCode/Hasvc-est = Pythoii/os_tieEt9nS |Figure 4線程實現(xiàn)結(jié)果2.進程實現(xiàn)(1) 原理multi processi ng. py模塊提供了對線程的操作。倉 J建線程 mult ip rocess ing.P rocess(target, args),target是要運行的函數(shù),args是函數(shù)所需的參數(shù)。倉 J建信號量 mult ip rocessi ng.Sema phore(value),

23、value是信號量的初始值。acquire() 信號量-1,當為0時,阻塞當前線程。release()信號量+1,大于0,喚醒等待此信號量的一個線程。創(chuàng)建互斥鎖,mult ip rocess in g.Lock(),acquire()力卩鎖,release()解鎖。12 / 19變量定義 list類型的定義 list類型的定義 list類型的定義方法father ,apples_basket 存放所有的蘋果oranges_basket 存放所有的橘子plate 當做水果盤,可以放入蘋果和橘子用于將蘋果放入水果盤,也就是把apples_basket的一個蘋果,放入 plate 列表中。并打印相關(guān)

24、信息。 定義方法 mather , 用于將蘋果放入水果盤, 也就是把oranges_basket的一個橘子,放入 plate 列表中。并打印相關(guān)信息。定義方法 son , 用于從水果盤取出一個橘子,也就是把 橘子,拿出來,并打印相關(guān)信息。plate 的一個定義方法 daughter , 用于從水果盤取出一個蘋果,也就是把 plate 的 一個蘋果,拿出來,并打印相關(guān)信息。3) 代碼import randomimport multiprocessingimport timeempty = multiprocessing.Semaphore(5) # 盤 子的容量 apple = multipro

25、cessing.Semaphore(0) # 同步蘋果的信號量 orange = multiprocessing.Semaphore(0) # 同步橘子的信號量mutex = multiprocessing.Event() # 表示四個 進程互斥的 訪問盤 子manager = multiprocessing.Manager()plate = manager.list() # 模擬水果 盤lock = multiprocessing.Lock() # plate 互斥鎖mutex.set() # 設(shè) 置為 Truedef father(basket):global empty, mutex,

26、lock, applewhile len(basket) != 0: # 當蘋果籃子中沒有蘋果, 則終止# 1.p(empty)empty.acquire() # 將容量 empty 減去 1# 2.p(mutex)mutex.clear() # mutex 設(shè)置 為 False 其它 線 程將等待18 / 19# 3.put appleif lock.acquire():temp = basket.pop() plate.append(temp) # 從蘋果 籃 子里拿出一個蘋果放入水果 盤print(-father put an apple(0) into plate.format(tem

27、p) print( current plate = , plate)lock.release()# 4.v(mutex) mutex.set() # mutex 設(shè)置 為 True, 其它 線程可以使用# 5.v(apple)apple.release() time.sleep(random.random() def mother(basket):global empty, mutex, lock, orange while len(basket) != 0: # 當橘子 籃子中沒有橘子, 則終 止# 1.p(empty)empty.acquire() # 將容量 empty 減去 1# 2.

28、p(mutex) mutex.clear() # mutex 設(shè)置 為 False 其它 進 程將等待# 3.put(orange)if lock.acquire():temp = basket.pop() plate.append(temp) print(-mother put an orange(0) into plate.format(temp)print( current plate = , plate) lock.release()# 4.v(mutex)mutex.set() # mutex 設(shè)置 為 True, 其它 進程可以使用# 5.v(orange) orange.rele

29、ase() time.sleep(random.random() def son(count):global empty, mutex, lock, orange for i in range(count):# 1.p(orange)orange.acquire() # orange -1# 2.p(mutex) mutex.clear() # mutex 設(shè)置 為 False 其它 進 程將等待# 3.get orangeif lock.acquire():for fruit in plate:if fruit.startswith(Orange): temp = fruit plate.r

30、emove(fruit) breakprint(-son take an orange(0) from plate.format(temp)print( current plate = , plate) lock.release()# 4.v(mutex) mutex.set() # mutex 設(shè)置 為 True, 其它 進程可以使用# 5.v(empty)empty.release() # 將 empty + 1 time.sleep(random.random() def daughter(count):global empty, mutex, lock, applefor i in r

31、ange(count):# 1.p(apple)apple.acquire() # apple -1# 2.p(mutex) mutex.clear() # mutex 設(shè)置 為 False 其它 進 程將等待# 3.get appleif lock.acquire():for fruit in plate:if fruit.startswith(Apple): temp = fruit plate.remove(fruit) breakprint(-daughter take an apple(0) from plate.format(temp)print( current plate =

32、, plate) lock.release()# 4.v(mutex) mutex.set() # mutex 設(shè)置 為 True, 其它 進程可以使用# 5.v(empty)empty.release() # 將 empty + 1time.sleep(random.random()if _name_ = _main_:# 初始化蘋果和橘子的個數(shù) apples_basket = Apple-A, Apple-B, Apple-C, Apple-D #模擬蘋果籃子,一共有 4 個蘋果要放入水果 盤oranges_basket = Orange-A, Orange-B, Orange-C # 模

33、擬橘子籃子,一共有 3 個橘子要放入水果 盤# 創(chuàng)建 4 個進程father = multiprocessing.Process(name=Father, target=father,args=(apples_basket, ) # father 進程mother = multiprocessing.Process(name=Mother, target=mother,args=(oranges_basket, ) # mother 進 程son = multiprocessing.Process(name=Son, target=son,args=(len(oranges_basket),

34、) # son 進程daughter = multiprocessing.Process(name=Daughter,target=daughter, args=(len(apples_basket), ) # daughter 進程# 啟動進 程daughter.start() son.start() father.start() mother.start() daughter.join() son.join() father.join() mother.join() print(End !)4) 結(jié)果wold甘old-pc: /MyCode/BaskTeit-Pytl1Dn/os_de%l

35、gnIs0 Evoid電votd-pc:/evccdc/BasicTf&ut-P$ naln-process.py f石in-threadpy voldvotd-pc:/wycedc/BastcTESt pyt冷c:i/c_dei;ign$ -mothfr put An orj)ngp(Orangfr-C) into plfltF.current plate = Orange-C -son take an orange(Orange-C fron plate, current plate-father put an current plate-daughter take current pla

36、te nothcr put an current plate-J apple(Apple-D into plate. =Apple-D an appTe(Apple-D) fron plate -J orangc(Orangc-D) into plotc. -orange-B5on take an orjngcfather put an current plate daughtcr take current plate Fiothcr put on Current plate=J ppIeCAppIt C into plate. =Appie-C jn opplefApple C) fron

37、plate =J orsngc(Orangc A) into plate. =Ofdftge-Ason tokc an orjngc current plate fathcr put on currpnt pte dQughtcr take currpnt pte -father put an currpnt plate -daughter take current plate End I=J jpplc(AppLc & =Apple-B jn opplc(AppIc =J ippIeCAppte-A) =Apple-Afron o plate.B) fron plotcinto plate.an apple(Apple-A) fron plate -J- pc: -/My Codey BasicTest -凸訃0時_女鞏腫$Figure 5進程實現(xiàn)結(jié)果Pythoni main-process.py六、總結(jié)因為之前就在慕課網(wǎng)上看過linux使用的教程,學過centos7字符界面的使用。在課程設(shè)計前就裝好了 winlO + Ubuntu 16.04 LTS雙系統(tǒng)。所以在熟悉linux使用上并沒有花時間。初期使用linux最大的麻煩就是安裝軟件。安裝方式有源碼安裝和二進制包安裝。使用熟

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論