第三章并發(fā)進(jìn)程_第1頁(yè)
第三章并發(fā)進(jìn)程_第2頁(yè)
第三章并發(fā)進(jìn)程_第3頁(yè)
第三章并發(fā)進(jìn)程_第4頁(yè)
第三章并發(fā)進(jìn)程_第5頁(yè)
已閱讀5頁(yè),還剩111頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

3.1并發(fā)進(jìn)程

3.2臨界區(qū)管理

3.3信號(hào)量與PV操作

3.4管程

3.5進(jìn)程通信

3.7死鎖

第3章并發(fā)進(jìn)程

3.1.1順序程序設(shè)計(jì)3.1.2并發(fā)程序設(shè)計(jì)3.1.3進(jìn)程的交互:競(jìng)爭(zhēng)和協(xié)作3.1并發(fā)進(jìn)程

3.1.1順序程序設(shè)計(jì)程序執(zhí)行的順序性程序在處理器上執(zhí)行時(shí)嚴(yán)格有序的,即只有當(dāng)一個(gè)操作結(jié)束后,才能開(kāi)始后繼操作,這稱為程序內(nèi)部的順序性如果完成一個(gè)任務(wù)需要若干個(gè)不同的程序,這些不同程序在時(shí)間上按調(diào)用次序嚴(yán)格有序執(zhí)行,這稱為程序外部的順序性傳統(tǒng)的程序設(shè)計(jì)方法是順序程序設(shè)計(jì),即把一個(gè)程序設(shè)計(jì)成一個(gè)順序執(zhí)行的程序模塊,不同程序也是按序執(zhí)行的順序程序設(shè)計(jì)的特點(diǎn)執(zhí)行的順序性環(huán)境的封閉性結(jié)果的確定性過(guò)程的可再現(xiàn)性3.1.2并發(fā)程序設(shè)計(jì)1.程序并發(fā)執(zhí)行進(jìn)程的并發(fā)性:一組進(jìn)程的執(zhí)行在時(shí)間上是重疊的所謂執(zhí)行在時(shí)間上是重疊的,是指一個(gè)進(jìn)程執(zhí)行的第一條指令是在另一個(gè)進(jìn)程執(zhí)行的最后一條指令完成之前開(kāi)始的例如:有兩個(gè)進(jìn)程A和B,進(jìn)程A執(zhí)行操作a1、a2、a3,進(jìn)程B執(zhí)行操作b1、b2、b3進(jìn)程A和B順序(串行)執(zhí)行的情況:在單處理器上,進(jìn)程A執(zhí)行完,進(jìn)程B才開(kāi)始執(zhí)行,它們的操作次序?yàn)椋篴1、a2、a3、b1、b2、b3進(jìn)程A和B并發(fā)執(zhí)行的一種情況:在單處理器上,進(jìn)程A和B交替(交叉)執(zhí)行,它們交替(交叉)執(zhí)行的操作次序可能為:a1、b1、b2、a2、a3、b3進(jìn)程的并發(fā)性從宏觀上看,并發(fā)性反映一個(gè)時(shí)間段中幾個(gè)進(jìn)程都在同一處理器上處于運(yùn)行還未運(yùn)行結(jié)束的狀態(tài)從微觀上看,任一時(shí)刻僅有一個(gè)進(jìn)程在處理器上運(yùn)行并發(fā)的實(shí)質(zhì)是一個(gè)處理器在幾個(gè)進(jìn)程之間的多路復(fù)用并發(fā)是對(duì)有限的物理資源強(qiáng)制行使多用戶共享,消除計(jì)算機(jī)部件之間的互等現(xiàn)象,以提高系統(tǒng)資源利用率在采用多道程序設(shè)計(jì)的系統(tǒng)中,利用了處理器與外圍設(shè)備、外圍設(shè)備與外圍設(shè)備之間的并行工作能力,提高了計(jì)算機(jī)的工作效率。進(jìn)程的并發(fā)性(續(xù))例如:程序P=while(I<Count){input(data[I],process

data[I],output

data[I])}對(duì)一批數(shù)據(jù)(Count組)進(jìn)行處理Input涉及對(duì)輸入設(shè)備的操作process涉及處理器的計(jì)算工作output涉及對(duì)輸出設(shè)備的操作程序的編制決定了程序的執(zhí)行一次僅能操作一臺(tái)物理設(shè)備,設(shè)備之間存在等待現(xiàn)象,循環(huán)迭代一次僅能處理一組數(shù)據(jù)程序P屬于串行執(zhí)行的程序進(jìn)程的并發(fā)性(續(xù))若對(duì)這個(gè)計(jì)算問(wèn)題改用三個(gè)程序來(lái)實(shí)現(xiàn):(I=J=K=1)輸入程序PI:while(I<Count){input(data[I++]),send}計(jì)算程序PC:while(J<Count){receive, process(data[J++]),send}輸出程序PO:while(K<Count){receive, output(data[K++])}send、receive為通信控制操作進(jìn)程的并發(fā)性(續(xù))輸入程序PI

計(jì)算程序PC 輸出程序POinput(data[1])input(data[2]) process(data[1])input(data[3]) process(data[2]) output(data[1])input(data[4]) process(data[3]) output(data[2])input(data[5]) process(data[4]) output(data[3]) process(data[5]) output(data[4]) output(data[5])t1t2t3t4t5t6t7進(jìn)程的并發(fā)性(續(xù))并發(fā)程序設(shè)計(jì):使一個(gè)程序分成若干個(gè)可同時(shí)執(zhí)行的程序模塊的方法稱為并發(fā)程序設(shè)計(jì)(如果這些模塊都屬于一個(gè)進(jìn)程,在進(jìn)程內(nèi)部執(zhí)行,則稱為并發(fā)多線程程序設(shè)計(jì);若模塊屬于不同進(jìn)程,則稱為并發(fā)多進(jìn)程程序設(shè)計(jì))2.并發(fā)進(jìn)程的特性

并發(fā)進(jìn)程之間的關(guān)系分為兩類:無(wú)關(guān)的和交互的無(wú)關(guān)的并發(fā)進(jìn)程:一組并發(fā)進(jìn)程分別在不同的變量集合上操作,一個(gè)進(jìn)程的執(zhí)行與其他并發(fā)進(jìn)程的進(jìn)展無(wú)關(guān),即一個(gè)并發(fā)進(jìn)程不會(huì)改變另一個(gè)并發(fā)進(jìn)程的變量值交互的并發(fā)進(jìn)程:一組并發(fā)進(jìn)程共享某些變量,一個(gè)進(jìn)程的執(zhí)行可能影響其他并發(fā)進(jìn)程的執(zhí)行結(jié)果。交互的并發(fā)進(jìn)程之間具有制約關(guān)系,這種交互必須是有控制的,否則會(huì)出現(xiàn)不正確的結(jié)果進(jìn)程的并發(fā)性(續(xù))并發(fā)進(jìn)程的無(wú)關(guān)性是進(jìn)程的執(zhí)行與時(shí)間無(wú)關(guān)的一個(gè)充分條件,又稱為Bernstein條件Bernstein條件:設(shè)

R(pi)={a1,a2,…an},程序pi在執(zhí)行期間引用的變量集

W(pi)={b1,b2,…bm},程序pi在執(zhí)行期間改變的變量集若兩個(gè)程序p1、p2的引用變量集與改變變量集交集之和為空集:

R(p1)∩W(p2)∪R(p2)∩W(p1)∪W(p1)∩W(p2)={}則并發(fā)進(jìn)程的執(zhí)行與時(shí)間無(wú)關(guān)

進(jìn)程的并發(fā)性(續(xù))并發(fā)可以是程序內(nèi)部語(yǔ)句之間或模塊之間的并發(fā),也可以是程序與程序之間的并發(fā)例如,一個(gè)程序PS有如下四條語(yǔ)句:S1:a=x+y;S2:b=z+1;S3:c=a–b;S4:w=c+1;這四條語(yǔ)句的書寫次序定義了一個(gè)串行程序的執(zhí)行流程,也定義了程序的邏輯意義,程序執(zhí)行時(shí)將按S1、S2、S3、S4的次序執(zhí)行。現(xiàn)在要將該程序PS進(jìn)行變換,得到一個(gè)并發(fā)程序PC,而且PC與PS等價(jià)分析:該問(wèn)題的核心是找出哪些語(yǔ)句能夠同時(shí)執(zhí)行,而這些語(yǔ)句同時(shí)執(zhí)行時(shí)對(duì)變量的訪問(wèn)和修改合乎程序PS的原有邏輯與時(shí)間有關(guān)的錯(cuò)誤對(duì)于一組交互的并發(fā)進(jìn)程,若執(zhí)行的相對(duì)速度無(wú)法相互控制,則各種與時(shí)間有關(guān)的錯(cuò)誤就可能出現(xiàn)與時(shí)間有關(guān)的錯(cuò)誤有兩種表現(xiàn)形式:結(jié)果不唯一永遠(yuǎn)等待…a1=n//n表示剩余的票數(shù)if(a1>=1){a1=a1-1;//售出一張票

n=a1;}…… …a2=n//n表示剩余的票數(shù)if(a2>=1){a2=a2-1;//售出一張票

n=a2;}…… 因?yàn)檫@種錯(cuò)誤和相對(duì)執(zhí)行速度有關(guān),因此稱為與時(shí)間有關(guān)的錯(cuò)誤。服務(wù)器售票員A售票員B與時(shí)間有關(guān)的錯(cuò)誤-結(jié)果不唯一與時(shí)間有關(guān)的錯(cuò)誤-永遠(yuǎn)等待

例:內(nèi)存管理問(wèn)題:有2個(gè)并發(fā)進(jìn)程borrow和return分別負(fù)責(zé)申請(qǐng)和歸還主存資源,下面算法中,x表示現(xiàn)有空閑主存容量,B表示申請(qǐng)或歸還的主存量。并發(fā)進(jìn)程的算法及執(zhí)行描述如下:voidborrow(intB){while(B>X) {進(jìn)程進(jìn)入等待隊(duì)列等主存資源}

X=X-B;

修改主存分配表,進(jìn)程獲得主存資源;}voidreturn(intB){X=X+B;

修改主存分配表釋放等主存資源的進(jìn)程

}intX=memory;cobegin repeatborrow(B); repeatreturn(B);coend3.1.3進(jìn)程的交互:競(jìng)爭(zhēng)和協(xié)作1.并發(fā)進(jìn)程之間的競(jìng)爭(zhēng)關(guān)系系統(tǒng)中的多個(gè)進(jìn)程之間彼此無(wú)關(guān),相互并不知道其它進(jìn)程的存在,相互之間并不交換信息。但是由于這些進(jìn)程共用了一套計(jì)算機(jī)系統(tǒng)資源,因而必然產(chǎn)生競(jìng)爭(zhēng)資源的問(wèn)題,一個(gè)進(jìn)程的執(zhí)行可能影響到同其競(jìng)爭(zhēng)資源的其它進(jìn)程。操作系統(tǒng)必須協(xié)調(diào)好諸進(jìn)程對(duì)資源的爭(zhēng)用。一旦一個(gè)進(jìn)程要使用已分配給另一個(gè)進(jìn)程的資源,則該進(jìn)程必須等待2.并發(fā)進(jìn)程之間的協(xié)作關(guān)系某些進(jìn)程為完成同一任務(wù)需要分工協(xié)作,由于合作的每一個(gè)進(jìn)程都是獨(dú)立地以不可預(yù)知的速度推進(jìn),這就需要相互協(xié)作的進(jìn)程在某些協(xié)調(diào)點(diǎn)上協(xié)調(diào)各自的工作。當(dāng)協(xié)作進(jìn)程中的一個(gè)到達(dá)協(xié)調(diào)點(diǎn)后,在尚未得到其伙伴進(jìn)程發(fā)來(lái)的消息或信號(hào)之前應(yīng)阻塞自己,直到其他合作進(jìn)程發(fā)來(lái)協(xié)調(diào)信號(hào)或消息后才被喚醒并繼續(xù)執(zhí)行。這種協(xié)作進(jìn)程之間相互等待對(duì)方消息或信號(hào)的協(xié)調(diào)關(guān)系稱為進(jìn)程同步競(jìng)爭(zhēng)(互斥)關(guān)系定義:當(dāng)多個(gè)進(jìn)程因?yàn)闋?zhēng)奪臨界資源而互斥執(zhí)行稱為進(jìn)程的互斥。臨界資源:也稱獨(dú)占資源,是指在一段時(shí)間內(nèi)只允許一個(gè)進(jìn)程訪問(wèn)的資源。例如打印機(jī),磁帶機(jī),也可以是進(jìn)程共享的數(shù)據(jù)、變量等。競(jìng)爭(zhēng)關(guān)系

資源競(jìng)爭(zhēng)產(chǎn)生兩個(gè)問(wèn)題:

一個(gè)是死鎖(Deadlock)問(wèn)題,就是一組進(jìn)程如果都獲得了部分資源,還想要得到其他進(jìn)程所占用的資源,最終所有進(jìn)程都將陷入死鎖一個(gè)是饑餓(Starvation)問(wèn)題,是指一個(gè)進(jìn)程由于其它進(jìn)程總是優(yōu)先于它而被無(wú)限期拖延既要解決饑餓問(wèn)題,又要解決死鎖問(wèn)題。協(xié)作(同步)關(guān)系data定義:進(jìn)程之間這種相互合作、協(xié)同工作的關(guān)系稱為進(jìn)程的同步。簡(jiǎn)單說(shuō)來(lái)就是:多個(gè)相關(guān)進(jìn)程在執(zhí)行次序上的協(xié)調(diào)。實(shí)例有2個(gè)進(jìn)程P1、P2,其中P1是計(jì)算進(jìn)程,P2是打印進(jìn)程,每當(dāng)P1計(jì)算出一個(gè)結(jié)果以后,將計(jì)算結(jié)果送到緩沖區(qū),以便P2進(jìn)程從中取出數(shù)據(jù)打印。假設(shè)緩沖區(qū)被劃分為0、1、2…k-1共k個(gè)單元。還設(shè)置了兩個(gè)指針:in指針用于計(jì)算進(jìn)程存放數(shù)據(jù),指向緩沖區(qū)下一個(gè)空閑的單元;out指針用于打印進(jìn)程取數(shù)據(jù),指向緩沖區(qū)下一個(gè)將要取走數(shù)據(jù)單元。…….0123456789k-1inout3.2.1互斥與臨界區(qū)3.2.2臨界區(qū)管理的嘗試3.2.3實(shí)現(xiàn)臨界區(qū)管理的軟件方法3.2.4實(shí)現(xiàn)臨界區(qū)管理的硬件設(shè)施

3.2臨界區(qū)管理

…a1=n//n表示剩余的票數(shù)if(a1>=1){a1=a1-1;//售出兩張票

n=a1;}…… …a2=n//n表示剩余的票數(shù)if(a2>=1){a2=a2-1;//售出一張票

n=a2;}…… 服務(wù)器售票員A售票員B臨界資源臨界區(qū):與臨界資源操作相關(guān)的程序段。3.2.1互斥與臨界區(qū)與同一變量有關(guān)的臨界區(qū)分散在各進(jìn)程的程序段中,而各進(jìn)程的執(zhí)行速度不可預(yù)知如果能保證進(jìn)程在臨界區(qū)執(zhí)行時(shí),不讓另一個(gè)進(jìn)程進(jìn)入臨界區(qū),即各進(jìn)程對(duì)共享變量的訪問(wèn)是互斥的,就不會(huì)造成與時(shí)間有關(guān)的錯(cuò)誤臨界區(qū)的調(diào)度原則一次至多允許一個(gè)進(jìn)程進(jìn)入臨界區(qū)內(nèi);如果已有進(jìn)程在臨界區(qū)中,試圖進(jìn)入此臨界區(qū)的其他進(jìn)程應(yīng)等待;進(jìn)入臨界區(qū)的進(jìn)程應(yīng)在有限時(shí)間內(nèi)退出,以便讓等待隊(duì)列中的一個(gè)進(jìn)程進(jìn)入臨界區(qū)調(diào)度原則可總結(jié)成三句話:互斥使用、有空讓進(jìn);忙則等待、有限等待;擇一而入、讓權(quán)等待、算法可行。算法可行是指不能因?yàn)樗x的調(diào)度策略造成進(jìn)程饑餓甚至死鎖。3.2.2臨界區(qū)管理的嘗試下面的程序是采用標(biāo)志方法實(shí)現(xiàn)互斥的一種嘗試booleaninside1=false;/*P1不在其臨界區(qū)內(nèi)*/boolean

inside2=false;/*P2不在其臨界區(qū)內(nèi)*/cobeginprocessP1{… whileinside2do{}; inside1=true;

臨界區(qū);

inside1=false;…}coendprocessP2{… whileinside1do{}; inside2=true;

臨界區(qū);

inside2=false;…}臨界區(qū)管理的嘗試(續(xù))下面是第二個(gè)嘗試:booleaninside1=false;/*P1不在其臨界區(qū)內(nèi)*/booleaninside2=false;/*P2不在其臨界區(qū)內(nèi)*/cobeginprocessP1{… inside1:=true; whileinside2do{};

臨界區(qū);

inside1:=false;…}

coend

processP2{…inside2:=true;whileinside1do{};

臨界區(qū);inside2:=false;…};改進(jìn)算法★初步設(shè)想◆進(jìn)程交替進(jìn)入臨界區(qū)。當(dāng)turn=0時(shí),P1必須等待P0進(jìn)入臨界區(qū)執(zhí)行,退出后,才能進(jìn)入臨界區(qū);即使此時(shí)臨界區(qū)空閑,不符合空閑讓進(jìn)◆任何進(jìn)程在臨界區(qū)內(nèi)或外失敗,其它進(jìn)程將可能因?yàn)榈却褂门R界區(qū)而無(wú)法向前推進(jìn)processP0{…inside[0]=true;turn=1;while(inside[1]&&turn==1) {donothing};

{臨界區(qū);}inside[0]=false;…}booleaninside[2];intturn=0or1;inside[0]=false;inside[1]=false;cobegin

coendprocessP1{…inside[1]=true;turn=0;while(inside[0]&&turn==0)

{donothing};

{臨界區(qū);}inside[1]=false;…}3.2.3實(shí)現(xiàn)臨界區(qū)管理的軟件方法Peterson算法

實(shí)現(xiàn)臨界區(qū)管理的軟件方法(續(xù))當(dāng)一個(gè)進(jìn)程沒(méi)有意圖進(jìn)入臨界區(qū)時(shí),另一個(gè)進(jìn)程可以立即進(jìn)入臨界區(qū)。當(dāng)兩個(gè)進(jìn)程都想進(jìn)入臨界區(qū)時(shí),如果turn=i,則只有第i個(gè)進(jìn)程可以進(jìn)入臨界區(qū)。一次只有一個(gè)進(jìn)程可以進(jìn)入臨界區(qū),因?yàn)樵谠撨M(jìn)程退出之前turn的值是不會(huì)改變的該算法雖然能解決互斥問(wèn)題但是算法復(fù)雜難以理解忙等3.2.4實(shí)現(xiàn)臨界區(qū)管理的硬件設(shè)施

使用軟件方法實(shí)現(xiàn)進(jìn)程互斥使用臨界資源是很困難的,他們通常能實(shí)現(xiàn)兩個(gè)進(jìn)程之間的互斥,很難控制多個(gè)進(jìn)程的互斥程序設(shè)計(jì)時(shí)應(yīng)該非常注意,否則就會(huì)產(chǎn)生死鎖和不能解決互斥軟件方法始終不能解決忙等,系統(tǒng)效率不高用來(lái)實(shí)現(xiàn)互斥的硬件設(shè)施主要有:關(guān)中斷、測(cè)試并建立指令、對(duì)換指令實(shí)現(xiàn)臨界區(qū)管理的硬件設(shè)施(續(xù))1.關(guān)中斷

關(guān)中斷是實(shí)現(xiàn)互斥的最簡(jiǎn)單方法之一進(jìn)程在測(cè)試標(biāo)志之前,首先關(guān)中斷,直到測(cè)試完并設(shè)置標(biāo)志之后才開(kāi)中斷進(jìn)程在臨界區(qū)執(zhí)行期間,計(jì)算機(jī)系統(tǒng)不響應(yīng)中斷因此,不會(huì)轉(zhuǎn)向調(diào)度,也就不會(huì)引起進(jìn)程或線程切換,正在執(zhí)行標(biāo)志測(cè)試和設(shè)置的進(jìn)程或線程不會(huì)被打斷,從而保證了互斥實(shí)現(xiàn)臨界區(qū)管理的硬件設(shè)施(續(xù))關(guān)中斷方法的缺點(diǎn):關(guān)中斷時(shí)間過(guò)長(zhǎng)會(huì)影響系統(tǒng)效率,限制處理器交叉執(zhí)行程序的能力關(guān)中斷方法也不適用于多CPU系統(tǒng),因?yàn)?,在一個(gè)處理器上關(guān)中斷,并不能防止進(jìn)程在其他處理器上執(zhí)行相同臨界區(qū)代碼實(shí)現(xiàn)臨界區(qū)管理的硬件設(shè)施(續(xù))2.測(cè)試并建立指令(專用的機(jī)器指令)硬件提供的測(cè)試并建立指令的執(zhí)行過(guò)程如下:TS(x):若x=true,則x=false;returntrue;否則returnfalse;TS指令管理臨界區(qū)時(shí),可把一個(gè)臨界區(qū)與一個(gè)布爾變量s相連,由于變量s代表了臨界資源的狀態(tài),可把它看成一把鎖

實(shí)現(xiàn)臨界區(qū)管理的硬件設(shè)施(續(xù))用TS指令實(shí)現(xiàn)臨界區(qū)管理(互斥)的算法如下:booleans=true; //沒(méi)有進(jìn)程在臨界區(qū)內(nèi)processPi()/*i=1,2,…,n*/{ while(!TS(s));//上鎖

臨界區(qū);

s=true;//開(kāi)鎖}

實(shí)現(xiàn)臨界區(qū)管理的硬件設(shè)施(續(xù))3.對(duì)換指令

對(duì)換(Swap)指令的功能是交換兩個(gè)字的內(nèi)容,處理過(guò)程如下:

voidSwap(boolean&a,boolean&b)temp=a;a=b;b=temp;在Intel80x86中,對(duì)換指令稱為XCHG指令實(shí)現(xiàn)臨界區(qū)管理的硬件設(shè)施(續(xù))用對(duì)換指令實(shí)現(xiàn)進(jìn)程互斥的程序如下:

booleanlock;lock=false; //無(wú)進(jìn)程在臨界區(qū)processPi()/*i=1,2,…,n*/{ boolean

keyi=true;do{

Swap(keyi,lock);//上鎖 }while(keyi);臨界區(qū);

Swap(keyi,lock);//開(kāi)鎖}實(shí)現(xiàn)臨界區(qū)管理的硬件設(shè)施(續(xù))導(dǎo)致饑餓:臨界區(qū)空閑時(shí),執(zhí)行循環(huán)檢測(cè)的若干進(jìn)程能進(jìn)入臨界區(qū)的幾率是相等的,有的進(jìn)程可能運(yùn)氣很不好,很難有機(jī)會(huì)進(jìn)入臨界區(qū),因而饑餓軟件方法和硬件方法都存在忙等問(wèn)題,浪費(fèi)了處理器的時(shí)間不會(huì)成為一種通用的方法3.3.1同步與同步機(jī)制3.3.2信號(hào)量與PV操作3.3.3信號(hào)量實(shí)現(xiàn)互斥3.3.4信號(hào)量解決5位哲學(xué)家吃通心面問(wèn)題3.3.5信號(hào)量解決生產(chǎn)者-消費(fèi)者問(wèn)題3.3.6信號(hào)量解決讀者-寫者問(wèn)題3.3.7信號(hào)量解決理發(fā)師問(wèn)題3.3信號(hào)量及其操作

3.3.1同步與同步機(jī)制著名的生產(chǎn)者--消費(fèi)者問(wèn)題是計(jì)算機(jī)操作系統(tǒng)中并發(fā)進(jìn)程內(nèi)在關(guān)系的一種抽象,是典型的進(jìn)程同步問(wèn)題。在操作系統(tǒng)中,生產(chǎn)者進(jìn)程可以是計(jì)算進(jìn)程、發(fā)送進(jìn)程;而消費(fèi)者進(jìn)程可以是打印進(jìn)程、接收進(jìn)程等等。解決好生產(chǎn)者--消費(fèi)者問(wèn)題就解決好了一類并發(fā)進(jìn)程的同步問(wèn)題生產(chǎn)者--消費(fèi)者問(wèn)題表述:有一環(huán)形緩沖池,包含k個(gè)緩沖區(qū)(0~k-1)。有兩類進(jìn)程:一組生產(chǎn)者進(jìn)程和一組消費(fèi)者進(jìn)程,生產(chǎn)者進(jìn)程向空的緩沖區(qū)中放產(chǎn)品,消費(fèi)者進(jìn)程從滿的緩沖區(qū)中取走產(chǎn)品生產(chǎn)者-消費(fèi)者必須同步…….0123456789k-1inout…….0123456789k-1inout生產(chǎn)者不能向滿緩沖區(qū)寫數(shù)據(jù),消費(fèi)者不能從空緩沖區(qū)取數(shù)據(jù),即生產(chǎn)者與消費(fèi)者必須同步。同步與同步機(jī)制(續(xù))

生產(chǎn)者進(jìn)程和消費(fèi)者進(jìn)程共享下面的變量intk;typedef

anyitemitem;itembuffer[k];//所有生產(chǎn)者進(jìn)程和消費(fèi)者進(jìn)程共享bufferintin,out,counter;//所有生產(chǎn)者進(jìn)程共享變量in//所有消費(fèi)者進(jìn)程共享變量out//所有生產(chǎn)者進(jìn)程和消費(fèi)者進(jìn)程共享counter生產(chǎn)者進(jìn)程:processproducer(void){

while(true){produceaniteminnextp;if(counter==k)sleep(producer);buffer[in]=nextp;in=(in+1)%k;counter=counter+1;if(counter==1)wakeup(consumer);}}消費(fèi)者進(jìn)程:processconsumer(void){While(true){if(counter==0)sleep(consumer);nextc=buffer[out];out=(out+1)%k;counter=counter-1;if(counter==k-1)wakeup(producer)consumetheiteminnextc;}}同步與同步機(jī)制(續(xù))出現(xiàn)錯(cuò)誤結(jié)果的原因在于各個(gè)進(jìn)程訪問(wèn)緩沖區(qū)的速率不同,要得到正確結(jié)果,需要調(diào)整并發(fā)進(jìn)程的速度,這需要通過(guò)在進(jìn)程間交換信號(hào)或消息來(lái)調(diào)整相互速率,達(dá)到進(jìn)程協(xié)調(diào)運(yùn)行的目的。這種協(xié)調(diào)過(guò)程稱為進(jìn)程同步操作系統(tǒng)實(shí)現(xiàn)進(jìn)程同步的機(jī)制稱為同步機(jī)制,它通常由同步原語(yǔ)組成常用的同步機(jī)制有:信號(hào)量與PV操作管程消息傳遞3.3.2信號(hào)量與PV操作1.前面種種方法解決臨界區(qū)調(diào)度問(wèn)題的缺點(diǎn)1)對(duì)不能進(jìn)入臨界區(qū)的進(jìn)程,采用忙等測(cè)試法,浪費(fèi)CPU時(shí)間2)將測(cè)試能否進(jìn)入臨界區(qū)的責(zé)任推給各個(gè)競(jìng)爭(zhēng)的進(jìn)程會(huì)削弱系統(tǒng)的可靠性,加重了用戶編程負(fù)擔(dān)2.信號(hào)量同步機(jī)制的提出1965年荷蘭計(jì)算機(jī)科學(xué)家E.W.Dijkstra提出了新的同步工具--信號(hào)量和P、V操作。他將交通管制中多種顏色的信號(hào)燈管理交通的方法引入操作系統(tǒng),讓兩個(gè)或多個(gè)進(jìn)程通過(guò)特殊變量展開(kāi)交互。一個(gè)進(jìn)程在某一特殊點(diǎn)上被迫停止執(zhí)行直到接收到一個(gè)對(duì)應(yīng)的特殊變量值,這種特殊變量就是信號(hào)量(Semaphore)。進(jìn)程可以使用P、V兩個(gè)特殊操作來(lái)發(fā)送和接收信號(hào)信號(hào)量與PV操作(續(xù))起信號(hào)燈作用的變量稱為信號(hào)量操作系統(tǒng)中,信號(hào)量是用來(lái)表示物理資源的實(shí)體,信號(hào)量是一種軟資源除賦初值外,信號(hào)量?jī)H能由同步原語(yǔ)P、V操作對(duì)其進(jìn)行操作。P、V操作的不可分割性確保執(zhí)行時(shí)的原子性及信號(hào)量值的完整性。利用信號(hào)量和P、V操作既可以解決并發(fā)進(jìn)程的競(jìng)爭(zhēng)問(wèn)題,又可以解決并發(fā)進(jìn)程的協(xié)作問(wèn)題一般信號(hào)量——結(jié)構(gòu)型信號(hào)量

typedefstructsemaphore{ intvalue;//可用資源數(shù)

structpcb*list;//阻塞隊(duì)列}voidP(semaphore&s){ s.value--;//信號(hào)量值減一 if(s.value<0)sleep(s.list);//若信號(hào)量值小于0,}阻塞當(dāng)前進(jìn)程。voidV(semaphore&s){ s.value++;//信號(hào)量值加一if(s.value≤0)wakeup(s.list);//若信號(hào)量值小于等于0,}

//喚醒s.list中一個(gè)進(jìn)程。P、V操作的應(yīng)用用P操作和V操作實(shí)現(xiàn)同步與互斥。s.value初值表示系統(tǒng)中某類資源的數(shù)目。進(jìn)程進(jìn)入臨界區(qū)之前,首先執(zhí)行P操作原語(yǔ),若s.value<0,則進(jìn)程調(diào)用sleep()內(nèi)核函數(shù),將自己阻塞,并插入到s.list隊(duì)列排隊(duì)。所以如果s.value<0,|s.value|表該信號(hào)量鏈表中已阻塞進(jìn)程的數(shù)目。當(dāng)其它進(jìn)程執(zhí)行了V操作原語(yǔ),若s.value<=0,說(shuō)明阻塞隊(duì)列中還有被阻塞的進(jìn)程,則調(diào)用wakeup()內(nèi)核函數(shù),把s.list中第一進(jìn)程修改為就緒狀態(tài),送到就緒隊(duì)列,準(zhǔn)備執(zhí)行臨界區(qū)代碼。propgrammutualexclusion;intn=...;/*進(jìn)程數(shù)*/semaphoremutex=1;/*定義信號(hào)量mutex,mutex.value初始化為1*/cobeginprocessPi()//i=1,2,…,n{P(mutex);<臨界區(qū)>;V(mutex);<其余程序>};coendvoidP(semaphore&s){ s.value--; if(s.value<0)sleep(s.list);}voidV(semaphore&s){ s.value++; if(s.value≤0)wakeup(s.list);}記錄型信號(hào)量與PV操作(續(xù))P(s)和V(s)中的s為兩個(gè)過(guò)程的共享變量s的取值:信號(hào)量s的初值在初始化時(shí),根據(jù)其用途進(jìn)行設(shè)置推論1:s.value>=0時(shí),s.value值表示還可以執(zhí)行P而不會(huì)被阻塞的進(jìn)程數(shù),每執(zhí)行一次P就意味著一次分配一個(gè)單位的資源推論2:當(dāng)s.value<0,表示沒(méi)有可用資源,請(qǐng)求該資源的進(jìn)程被阻塞。s.value的絕對(duì)值表示被阻塞的進(jìn)程數(shù),執(zhí)行一次V就意味著釋放一個(gè)資源。若s.value<0表示還有被阻塞的進(jìn)程,需要喚醒一個(gè)被阻塞的進(jìn)程,使他到就緒隊(duì)列中排隊(duì)推論3:通常,P操作意味著請(qǐng)求一個(gè)資源,V操作意味著釋放一個(gè)資源;特定條件下P操作代表阻塞進(jìn)程的操作,V操作代表喚醒被進(jìn)程的操作。信號(hào)量的分類

信號(hào)量按其用途分為兩種:公用信號(hào)量:初值常常為1,用來(lái)實(shí)現(xiàn)進(jìn)程間的互斥。相關(guān)進(jìn)程均可對(duì)其執(zhí)行P、V操作私有信號(hào)量:初值常常為可用資源數(shù),多用來(lái)實(shí)現(xiàn)進(jìn)程同步。擁有該信號(hào)量的一類進(jìn)程可以對(duì)其執(zhí)行P操作,而另一類進(jìn)程可以對(duì)其執(zhí)行V操作信號(hào)量按其取值分為兩種:二元信號(hào)量:僅取0和1,主要用于解決進(jìn)程互斥問(wèn)題一般信號(hào)量:允許取值為非負(fù)整數(shù),主要用于解決進(jìn)程同步問(wèn)題信號(hào)量的應(yīng)用我們將分析這樣幾個(gè)經(jīng)典進(jìn)程的同步問(wèn)題:(1)哲學(xué)家進(jìn)餐問(wèn)題(2)讀者--寫者問(wèn)題(3)生產(chǎn)者--消費(fèi)者問(wèn)題(4)理發(fā)師問(wèn)題3.3.4哲學(xué)家進(jìn)餐問(wèn)題五位哲學(xué)家圍坐一張圓桌,桌上放五根筷子,每位哲學(xué)家只能拿起與他相鄰的兩根筷子吃飯哲學(xué)家的生活方式是交替地進(jìn)行思考和進(jìn)餐哲學(xué)家筷子0011223344哲學(xué)家進(jìn)餐問(wèn)題(續(xù))1.利用結(jié)構(gòu)型信號(hào)量解決哲學(xué)家進(jìn)餐問(wèn)題數(shù)據(jù)結(jié)構(gòu):每根筷子都是一個(gè)臨界資源,都應(yīng)定義一個(gè)信號(hào)量,為五根筷子定義一個(gè)信號(hào)量數(shù)組,每個(gè)信號(hào)量的初值為1算法分析:若每個(gè)哲學(xué)家都各自拿起他左邊的一根筷子,然后再去拿他右邊的筷子時(shí),將都拿不到右邊的筷子,大家又都不會(huì)放下手中的筷子,大家在相互等待別人釋放筷子,系統(tǒng)于是進(jìn)入死鎖狀態(tài)操作描述:第i位哲學(xué)家的活動(dòng)如下:

Semaphorefork[5];for(inti=0;i<5;i++)fork[i].value=1;

cobeginProcessphilosopher_i(){

while(true){think();

P(fork[i]);

P(fork[(i+1)mod5]); eating;

V(fork[i]);

V(fork[(i+1)mod5]); }}

coend哲學(xué)家筷子0011223344哲學(xué)家進(jìn)餐問(wèn)題(續(xù))死鎖問(wèn)題解決方案:1)至多允許有四位哲學(xué)家同時(shí)去拿左邊的筷子,最終保證至少有一位哲學(xué)家能夠進(jìn)餐,(至多可以有兩位哲學(xué)家能夠進(jìn)餐)2)規(guī)定奇數(shù)號(hào)哲學(xué)家先拿他左邊的筷子,然后再去拿右邊的筷子;偶數(shù)號(hào)哲學(xué)家先拿他右邊的筷子,然后再去拿左邊的筷子3)每個(gè)哲學(xué)家取到手邊的兩把筷子才開(kāi)始進(jìn)餐,否則一根也不要3.3.5多緩沖區(qū)生產(chǎn)者-消費(fèi)者問(wèn)題對(duì)于m個(gè)生產(chǎn)者和n個(gè)消費(fèi)者,它們共享可存放k件產(chǎn)品的緩沖區(qū)操作要求:多個(gè)生產(chǎn)者進(jìn)程之間、多個(gè)消費(fèi)者進(jìn)程之間、生產(chǎn)者進(jìn)程與消費(fèi)者進(jìn)程之間均能正確同步生產(chǎn)者/消費(fèi)者必須同步…….0123456789k-1inout…….0123456789k-1inout生產(chǎn)者不能向滿緩沖區(qū)寫數(shù)據(jù),消費(fèi)者不能從空緩沖區(qū)取數(shù)據(jù),即生產(chǎn)者與消費(fèi)者必須同步。生產(chǎn)者/消費(fèi)者必須互斥…….0123456789k-1inout生產(chǎn)者和消費(fèi)者必須互斥進(jìn)入緩沖區(qū),即,某時(shí)刻只允許一個(gè)進(jìn)程(生產(chǎn)者或消費(fèi)者)訪問(wèn)緩沖區(qū),生產(chǎn)者必須互斥消費(fèi)者和其它任何生產(chǎn)者。P1將計(jì)算出來(lái)的數(shù)據(jù)放入in指針指向的6號(hào)單元,然后將in指向下個(gè)空閑單元-7號(hào)單元。P2將計(jì)算出來(lái)的數(shù)據(jù)放入in指針指向的7號(hào)單元,P2被中斷。P1將計(jì)算出來(lái)的數(shù)據(jù)放入in指針指向的7號(hào)單元,覆蓋了P2存放的數(shù)據(jù),出錯(cuò)!生產(chǎn)一條數(shù)據(jù)是否有空存儲(chǔ)單元是否可用存入一條數(shù)據(jù)歸還使用權(quán)數(shù)據(jù)單元加1,喚醒一個(gè)消費(fèi)者等待資源,阻塞被喚醒等待使用權(quán),阻塞被喚醒無(wú)否有是生產(chǎn)者消費(fèi)者空單元加1,喚醒一個(gè)生產(chǎn)者是否有數(shù)據(jù)單元是否可用取走一條數(shù)據(jù)歸還使用權(quán)消費(fèi)數(shù)據(jù)等待資源,阻塞被喚醒等待使用權(quán),阻塞被喚醒無(wú)否有是生產(chǎn)者-消費(fèi)者問(wèn)題1.利用記錄型信號(hào)量解決生產(chǎn)者--消費(fèi)者問(wèn)題

數(shù)據(jù)結(jié)構(gòu):1)含有k個(gè)緩沖區(qū)的公用緩沖池2)互斥信號(hào)量mutex:實(shí)現(xiàn)諸進(jìn)程對(duì)緩沖池的互斥使用,一次僅允許一個(gè)進(jìn)程讀或?qū)懝镁彌_池,初值為13)資源信號(hào)量empty:記錄空緩沖區(qū)個(gè)數(shù),初值為k4)資源信號(hào)量full:記錄滿緩沖區(qū)個(gè)數(shù),初值為0操作要求:多個(gè)生產(chǎn)者進(jìn)程之間、多個(gè)消費(fèi)者進(jìn)程之間、生產(chǎn)者進(jìn)程與消費(fèi)者進(jìn)程之間均能正確同步itemB[k];Semaphoreempty,full,mutex;empty=k;full=0;mutex=1;Intin=0;out=0;cobeginprocessproducer_i(){ while(true){produce();

P(empty);

P(mutex);appendtoB[in];in=(in+1)%k;

V(mutex);

V(full);}}processconsumer_j(){while(true){

P(full);

P(mutex);take()fromB[out];out=(out+1)%k;

V(mutex);

V(empty);consume();}}coend生產(chǎn)者-消費(fèi)者問(wèn)題(續(xù))注意:1)在每個(gè)程序中用于互斥的P(mutex)和V(mutex)必須成對(duì)出現(xiàn)2)對(duì)資源信號(hào)量empty和full的操作也同樣必須成對(duì)出現(xiàn),但它們?cè)诓煌某绦蛑?)在每個(gè)程序中的多個(gè)P操作順序不能顛倒,否則容易引起死鎖3.3.6讀者寫者問(wèn)題該問(wèn)題為多個(gè)進(jìn)程訪問(wèn)一個(gè)共享數(shù)據(jù)區(qū),如數(shù)據(jù)庫(kù)、文件、內(nèi)存區(qū)、寄存器等數(shù)據(jù)問(wèn)題建立了一個(gè)通用模型,其中讀進(jìn)程只能讀數(shù)據(jù),寫進(jìn)程只能寫數(shù)據(jù)。多個(gè)Reader進(jìn)程同時(shí)讀一條數(shù)據(jù)可以的,但如果一個(gè)Writer進(jìn)程正在更新數(shù)據(jù)時(shí),則所有其他進(jìn)程都不能訪問(wèn)(讀或?qū)懀┰撚涗?。data讀者讀者寫者寫者讀者優(yōu)先當(dāng)一個(gè)讀者正在讀數(shù)據(jù)時(shí),另一個(gè)讀者也需要讀數(shù)據(jù),應(yīng)該允許第二個(gè)讀者進(jìn)入,同理第三個(gè)及隨后更多的讀者都被允許進(jìn)入?,F(xiàn)在假設(shè)一個(gè)寫者到來(lái),由于寫操作時(shí)排他的,所以它不能訪問(wèn)數(shù)據(jù),需要阻塞等待。如果一直都有新的讀者陸續(xù)到來(lái),寫者的寫操作將被嚴(yán)重推遲。該方法稱為“讀者優(yōu)先”。即,一旦有讀者正在讀數(shù)據(jù),允許多個(gè)讀者同時(shí)進(jìn)入讀數(shù)據(jù),只有當(dāng)全部讀者退出,才允許寫者進(jìn)入寫數(shù)據(jù)。讀者寫者問(wèn)題(續(xù))1.利用記錄型信號(hào)量解決讀者-----寫者問(wèn)題數(shù)據(jù)結(jié)構(gòu):1)互斥信號(hào)量writeblock:用于Reader與Writer、Writer與Writer之間的互斥,初值為1;2)ReadCount:正在讀的進(jìn)程數(shù)目,初值為03)互斥信號(hào)量mutex:用于Reader與Reader互斥訪問(wèn)整型量ReadCount,初值為1

semaphoremutex=1,writeblock=1; intReadCount=0;

cobegin processreader_i{

P(mutex);ifReadCount==0thenP(writeblock); ReadCount:=ReadCount+1;

V(mutex); {讀文件};

P(mutex); ReadCount:=ReadCount-1; ifReadCount==0thenV(writeblock);

V(mutex); }

coendprocesswriter_j(){

P(writeblock);{寫文件};

V(writeblock);}3.3.7信號(hào)量解決理發(fā)師問(wèn)題理發(fā)店有一位理發(fā)師、一把理發(fā)椅和n把供等候理發(fā)的顧客坐的椅子。如果沒(méi)有顧客,理發(fā)師便在理發(fā)椅上睡覺(jué)。當(dāng)一個(gè)顧客到來(lái)時(shí),它必須叫醒理發(fā)師。如果理發(fā)師正在理發(fā)時(shí)又有顧客來(lái)到,則如果有空椅子可坐,他們就坐下來(lái)等待,否則就離開(kāi)。記錄型信號(hào)量解決理發(fā)師問(wèn)題intwaiting=0;//等候理發(fā)的顧客數(shù)

intCHAIRS=N;//為顧客準(zhǔn)備的椅子數(shù)

semaphore

customers=0,barbers=0,mutex=1;procedurebarber(){While(true)

{P(cutomers);

P(mutex);

waiting:=waiting–1;

V(barbers);

V(mutex);

cut-hair();}}procedurecustomer(){P(mutex);

if(waiting<CHAIRS){waiting:=waiting+1;

V(customers);

V(mutex);

P(barbers);

get_haircut();}elseV(mutex);}3.4.1管程和條件變量3.4.2管程的實(shí)現(xiàn)3.4.3使用管程解決進(jìn)程同步問(wèn)題3.4 管程

3.4.1管程和條件變量1.為什么要引入管程信號(hào)量機(jī)制的缺點(diǎn):進(jìn)程自備同步操作,P(S)和V(S)操作大量分散在各個(gè)進(jìn)程中,不易管理,易發(fā)生死鎖管程特點(diǎn):管程集中封裝了同步操作,對(duì)進(jìn)程隱蔽了同步細(xì)節(jié),簡(jiǎn)化了同步功能的調(diào)用界面。用戶編寫并發(fā)程序如同編寫串行程序引入管程機(jī)制的目的:把分散在各進(jìn)程中的臨界區(qū)集中起來(lái)進(jìn)行管理防止進(jìn)程有意或無(wú)意的違反同步操作便于用高級(jí)語(yǔ)言來(lái)書寫程序,也便于程序正確性驗(yàn)證管程和條件變量(續(xù))管程基本思想:把分散在各個(gè)進(jìn)程中的臨界區(qū)集中起來(lái)管理,并把共享資源用數(shù)據(jù)結(jié)構(gòu)抽象地表示出來(lái)建立一個(gè)“秘書”程序管理到來(lái)的訪問(wèn)“秘書”每次只讓一個(gè)進(jìn)程來(lái)訪,后“秘書”更名為管程對(duì)共享資源的管理可以借助數(shù)據(jù)結(jié)構(gòu)及其上所實(shí)施操作單若干進(jìn)程來(lái)進(jìn)行對(duì)共享資源的申請(qǐng)和釋放通過(guò)進(jìn)程在數(shù)據(jù)結(jié)構(gòu)上的操作來(lái)實(shí)現(xiàn)代表共享資源的數(shù)據(jù)結(jié)構(gòu)及并發(fā)進(jìn)程在其上執(zhí)行的一組過(guò)程構(gòu)成了管程管程和條件變量(續(xù))2.什么是管程一個(gè)管程定義了一個(gè)數(shù)據(jù)結(jié)構(gòu)和能為并發(fā)進(jìn)程所執(zhí)行的在該數(shù)據(jù)結(jié)構(gòu)上的一組操作,這組操作能同步進(jìn)程和改變管程中的數(shù)據(jù)。3.管程的三個(gè)組成部分1)局部于管程的共享變量2)對(duì)數(shù)據(jù)結(jié)構(gòu)進(jìn)行操作的一組過(guò)程3)對(duì)局部于管程的數(shù)據(jù)進(jìn)行初始化的語(yǔ)句管程和條件變量(續(xù))說(shuō)明:管程內(nèi)的數(shù)據(jù)結(jié)構(gòu)是私有的,只能在管程內(nèi)使用,管程內(nèi)的過(guò)程也只能使用管程內(nèi)的數(shù)據(jù)結(jié)構(gòu)進(jìn)程通過(guò)調(diào)用管程的過(guò)程使用臨界資源。任一時(shí)刻,管程中只能有一個(gè)活躍進(jìn)程。也就是說(shuō)對(duì)管程的使用是互斥的conditionc1wait(c1)…conditioncnwait(cn)urgentqueuesignal局部數(shù)據(jù)條件變量過(guò)程1過(guò)程k出口初始化代碼入口管程等待調(diào)用的進(jìn)程隊(duì)列管程等待區(qū)域…管程的結(jié)構(gòu)

3.5.1信號(hào)通信機(jī)制3.5.2管道通信機(jī)制3.5.3共享存儲(chǔ)區(qū)通信機(jī)制3.5.4消息通信機(jī)制

3.5進(jìn)程通信

什么是進(jìn)程通信?簡(jiǎn)單來(lái)說(shuō)就是在進(jìn)程間傳輸數(shù)據(jù)(交換信息)。進(jìn)程通信的方式根據(jù)交換信息量的多少和效率的高低,分為:低級(jí)通信:只能傳遞狀態(tài)和整數(shù)值(控制信息)進(jìn)程1進(jìn)程2P、V操作缺點(diǎn):傳送信息量小,效率低,每次通信傳遞的信息量固定,若傳遞較多信息則需要進(jìn)行多次通信。編程復(fù)雜:用戶直接實(shí)現(xiàn)通信的細(xì)節(jié),容易出錯(cuò)。高級(jí)通信:提高信號(hào)通信的效率,傳遞大量數(shù)據(jù),減輕程序編制的復(fù)雜度。進(jìn)程1進(jìn)程2data提供三種方式:1、管道通信2、共享存儲(chǔ)區(qū)方式3、消息傳遞方式3.5.1信號(hào)通信機(jī)制信號(hào)通信機(jī)制信號(hào)機(jī)制又稱軟中斷,是一種進(jìn)程之間進(jìn)行通信的簡(jiǎn)單通信機(jī)制,通過(guò)發(fā)送一個(gè)指定的信號(hào)來(lái)通知進(jìn)程某個(gè)異常時(shí)間發(fā)生,并進(jìn)行適當(dāng)處理軟中斷例子:軟中斷鍵與硬中斷的差別:軟中斷運(yùn)行在用戶態(tài),往往延時(shí)較長(zhǎng)硬中斷運(yùn)行在核心態(tài),能及時(shí)發(fā)現(xiàn)信號(hào)的發(fā)送:可以由內(nèi)核發(fā)給用戶進(jìn)程也可以由用戶進(jìn)程發(fā)送給其他的進(jìn)程。在unix系統(tǒng)中使用kill函數(shù)可以發(fā)送信號(hào)到某個(gè)進(jìn)程或某組進(jìn)程。在unix系統(tǒng)中定義了幾十種系統(tǒng)信號(hào)3.5.2管道通信機(jī)制管道:是連接讀寫進(jìn)程實(shí)現(xiàn)他們之間通信的一個(gè)特殊文件。屬于一種共享文件通信機(jī)制管道:是一個(gè)共享文件,連接讀寫進(jìn)程實(shí)現(xiàn)通信。寫進(jìn)程往管道一端寫入信息,讀進(jìn)程從管道另一端讀信息。管道可借助于文件系統(tǒng)的機(jī)制實(shí)現(xiàn),包括(管道)文件的創(chuàng)建、打開(kāi)、關(guān)閉和讀寫也稱共享文件方式,基于文件系統(tǒng),利用一個(gè)打開(kāi)的共享文件連接兩個(gè)相互通信的進(jìn)程,文件作為緩沖傳輸介質(zhì)發(fā)送進(jìn)程接收進(jìn)程以字符流方式寫入讀出,按先進(jìn)先出方式傳送數(shù)據(jù)管道通信機(jī)制

(續(xù))管道機(jī)制應(yīng)具備的三個(gè)協(xié)調(diào)功能:1)互斥。一次僅由一個(gè)進(jìn)程讀寫。(通過(guò)測(cè)試i_node節(jié)點(diǎn)的特征位來(lái)保證,改特征位就是一個(gè)讀寫互斥標(biāo)志)2)確定對(duì)方是否存在3)同步。睡眠和喚醒功能。(管道文件只使用了i_node節(jié)點(diǎn)中的直接地址項(xiàng),長(zhǎng)度一般限制在幾kb)4)進(jìn)程在關(guān)閉管道的讀出或?qū)懭霑r(shí),應(yīng)喚醒等待寫或讀此管道的進(jìn)程3.5.3共享存儲(chǔ)區(qū)通信機(jī)制內(nèi)存需要交換信息的兩個(gè)進(jìn)程,通過(guò)對(duì)同一共享數(shù)據(jù)區(qū)的操作實(shí)現(xiàn)互相通信。原理進(jìn)程1進(jìn)程2申請(qǐng)申請(qǐng)datadata這種通信方式不要求數(shù)據(jù)移動(dòng),一般用于本地通信。對(duì)于遠(yuǎn)程通信來(lái)說(shuō),不宜實(shí)現(xiàn)共享存儲(chǔ)區(qū)的訪問(wèn)。共享區(qū)3.5.4消息傳遞通信機(jī)制這里的消息是指進(jìn)程之間傳遞的大量的、具有格式的信息。消息的格式與消息傳遞的機(jī)制及消息的范圍有關(guān)。消息體消息格式消息頭消息類型目的端地址源端地址消息長(zhǎng)度控制信息消息傳遞通信機(jī)制(續(xù))采用消息傳遞機(jī)制后,進(jìn)程間通過(guò)消息來(lái)交換信息一個(gè)正在執(zhí)行的進(jìn)程可在任何時(shí)刻向另一個(gè)正在執(zhí)行的進(jìn)程發(fā)送消息一個(gè)正在執(zhí)行的進(jìn)程也可在任何時(shí)刻向正在執(zhí)行的另一個(gè)進(jìn)程請(qǐng)求消息如果進(jìn)程在某一時(shí)刻的執(zhí)行依賴于另一進(jìn)程的消息或等待其他進(jìn)程對(duì)所發(fā)消息的應(yīng)答,則消息機(jī)制與進(jìn)程的阻塞和釋放相聯(lián)系消息傳遞不僅具有進(jìn)程通信的能力,還提供進(jìn)程同步的能力消息傳遞通信機(jī)制(續(xù))消息傳遞通信方式分兩類:直接通信(消息緩沖區(qū))方式間接通信(信箱)方式消息傳遞工作原理進(jìn)程A進(jìn)程B原語(yǔ)Send(B,m)消息原語(yǔ)Receive(m)消息緩沖區(qū)進(jìn)程B的消息隊(duì)列進(jìn)程C的消息隊(duì)列進(jìn)程A的消息隊(duì)列消息不阻塞發(fā)送,阻塞接收Send()和Receive()通信原語(yǔ)ProcedureSend(receiver,

Ma)begingetbuf(Ma,size,i);

i.sender:=Ma.sender;

i.size:=Ma.size;

i.text:=Ms.text;

i.next:=0;

getid(PCBset,receiver,j);

P(j.mutex);

insert(j.Hptr,i);

V(j.Sn);

V(j.mutex);

endProcedureReceive(Mb)beginj:internalname;

P(j.Sn);

P(j.mutex);

remove(j.Hptr,i);

V(j.mutex);

Mb.Sender:=i.Sender;

Mb.Size:=i.Size;

Mb.text:=i.text;

end消息傳遞中的尋址直接尋址(直接通信)方式:點(diǎn)到點(diǎn)的發(fā)送

Send(destination,message);

Receive(source,message);間接尋址(間接通信)方式:以信箱為媒介進(jìn)行傳遞

Send(mailbox,message);

Receive(mailbox,message);進(jìn)程A進(jìn)程B原語(yǔ)Send(…)原語(yǔ)Receive(…)Mailbox利用消息傳遞實(shí)現(xiàn)互斥采用“不阻塞發(fā)送,阻塞接收”方式。多個(gè)并發(fā)執(zhí)行的發(fā)送進(jìn)程和接收進(jìn)程共享一個(gè)郵箱box,它被初始化為一個(gè)無(wú)內(nèi)容的“空”消息。如果一個(gè)進(jìn)程希望進(jìn)入臨界區(qū),首先必須申請(qǐng)從box郵箱中接收一條消息。若郵箱為“空”,則該進(jìn)程阻塞(接收);若進(jìn)程收到郵箱中的一條消息,則進(jìn)入臨界區(qū),執(zhí)行完畢以后,退出臨界區(qū),并將該消息發(fā)送回郵箱box中。constn=…;/*進(jìn)程數(shù)*/voidPi(){ messagemsg; while(true){ receive(box,msg);/*從郵箱接收一條消息*/ <臨界區(qū)>; send(box,msg);/*將消息發(fā)回郵箱*/ <其余部分>} begin/*主程序*/ create_mailbox(box);/*創(chuàng)建郵箱*/ send(box,null);/*初始化,向郵箱發(fā)送一條空消息*/

cobegin

P(1);P(2);…P(n)

coend end利用消息傳遞解決生產(chǎn)者/消費(fèi)者問(wèn)題供使用了capacity條消息,類似于共享內(nèi)存緩沖區(qū)中capacity個(gè)存儲(chǔ)單元。首先將capacity條“空”消息發(fā)送給生產(chǎn)者。當(dāng)生產(chǎn)者向消費(fèi)者傳遞一個(gè)數(shù)據(jù)項(xiàng)時(shí),它取走一條“空”消息,并發(fā)送回一條填充了內(nèi)容的消息。通過(guò)這種方式進(jìn)行數(shù)據(jù)傳遞,系統(tǒng)中的總消息數(shù)保持不變,所以,消息可以存放在預(yù)知數(shù)量的內(nèi)存中。如果生產(chǎn)者產(chǎn)生數(shù)據(jù)的速度比消費(fèi)者消費(fèi)數(shù)據(jù)的速度快,則所有的“空”消息最終都將被填滿,于是生產(chǎn)者將因?yàn)榻邮詹坏健翱铡毕⒍枞?,等待消費(fèi)者取走帶有數(shù)據(jù)的消息,然后返回一條“空”消息。如果消費(fèi)者消費(fèi)數(shù)據(jù)的速度快,則消費(fèi)者因?yàn)榻邮詹坏健皵?shù)據(jù)”消息而阻塞,直到生產(chǎn)者生產(chǎn)并發(fā)送一條“數(shù)據(jù)”消息。propgrammutualexclusion;intcapacity=...;/*消息緩沖區(qū)大小*/null=...;/*空消息*/voidproducer(){while(true){receive(mayproduce,null);pmsg:=produce;send(mayconsume,pmsg);}}

begin/*主程序*/create_mailbox(mayproduce);create_mailbox(mayconsume);fori=1tocapacitydosend(mayproduce,null);cobeginproducer;consumer;coendendvoidconsumer(){while(true){receive(mayconsume,cmsg);consume(cmsg);send(mayproduce,null);}}

3.6.1死鎖產(chǎn)生3.6.2死鎖防止3.6.3死鎖避免3.6.4死鎖的檢測(cè)和解除3.6死鎖

3.6.1死鎖的產(chǎn)生和定義例1:兩個(gè)同學(xué)同時(shí)進(jìn)入只有一張書桌和一把凳子的房間學(xué)習(xí),假設(shè)必需擁有書桌和凳子,方可學(xué)習(xí)。如果在某個(gè)時(shí)刻,A同學(xué)申請(qǐng)得到書桌,而B同學(xué)申請(qǐng)到凳子,A和B都希望得到對(duì)方的資源,而又不肯放手已經(jīng)占有的資源,這時(shí)就發(fā)生了僵持局面。例2:在哲學(xué)家進(jìn)餐問(wèn)題中,5個(gè)哲學(xué)家,每人各執(zhí)一個(gè)筷子,任何人都沒(méi)有兩個(gè)筷子進(jìn)餐。例3:在生產(chǎn)者—消費(fèi)者問(wèn)題中,將生產(chǎn)者或消費(fèi)者進(jìn)程的兩個(gè)P操作顛倒時(shí)也會(huì)發(fā)生死鎖。死鎖的產(chǎn)生和定義(續(xù))死鎖——多個(gè)進(jìn)程運(yùn)行過(guò)程中因爭(zhēng)奪資源而造成的一種僵局,無(wú)外力作用,它們都無(wú)法向前推進(jìn)。有關(guān)死鎖的結(jié)論:參與死鎖的進(jìn)程最少是兩個(gè)(兩個(gè)以上進(jìn)程才會(huì)出現(xiàn)死鎖)參與死鎖的進(jìn)程至少有兩個(gè)已經(jīng)占有資源參與死鎖的所有進(jìn)程都在等待資源參與死鎖的進(jìn)程是當(dāng)前系統(tǒng)中所有進(jìn)程的子集如果死鎖發(fā)生,會(huì)浪費(fèi)大量系統(tǒng)資源,甚至導(dǎo)致系統(tǒng)崩潰產(chǎn)生死鎖的條件1.互斥:競(jìng)爭(zhēng)的資源一次只能被一個(gè)進(jìn)程使用。2.占有且等待:當(dāng)一個(gè)進(jìn)程占有一些資源,同時(shí)又申請(qǐng)新的資源,如果新資源申請(qǐng)失敗,進(jìn)程將占有資源且阻塞等待。3.不剝奪:進(jìn)程已占有的資源不能被其它進(jìn)程強(qiáng)行剝奪。4.循環(huán)等待:在系統(tǒng)中存在一個(gè)由若干進(jìn)程形成的環(huán)形請(qǐng)求鏈,其中的每一個(gè)進(jìn)程均占有一些資源,同時(shí)又申請(qǐng)環(huán)形請(qǐng)求鏈中下一個(gè)進(jìn)程所占有的資源。前3個(gè)條件為必要條件,第4個(gè)條件為前3個(gè)條件可能導(dǎo)致的結(jié)果,為死鎖的充分條件,4個(gè)條件共同組成了死鎖的充分必要條件。解決死鎖的方法1.死鎖防止:破壞4個(gè)條件之一;有效,使資源利用率低。2.死鎖避免:防止進(jìn)入不安全態(tài)。3.死鎖檢測(cè)與恢復(fù):檢測(cè)到死鎖再清除。死鎖防止是通過(guò)限制死鎖產(chǎn)生的4個(gè)充要條件之一,以預(yù)防死鎖的發(fā)生。1.互斥條件是臨界資源固有屬性,不能避免。2.禁止“占有且等待”條件:全分配,全釋放(AND)缺點(diǎn):(1)延遲進(jìn)程運(yùn)行 (2)資源嚴(yán)重浪費(fèi)3.禁止“不剝奪”條件 增加系統(tǒng)開(kāi)銷,且進(jìn)程前段工作可能失效。3.6.2死鎖防止4.禁止“環(huán)路等待”條件有序資源分配法:為資源編號(hào),申請(qǐng)時(shí)需按編號(hào)進(jìn)行。缺點(diǎn):(1)新增新設(shè)備類型不便,(原序號(hào)已排定)(2)資源與進(jìn)程使用順序不同造成浪費(fèi)(3)增加了程序設(shè)計(jì)難度例:系統(tǒng)中有四類資源編號(hào)為:1.輸入機(jī)4.打印機(jī) 7.磁帶機(jī) 9.磁盤機(jī)現(xiàn)有兩個(gè)進(jìn)程P1、P2都要使用打印機(jī)和磁盤機(jī),P1先使用打印機(jī)后使用磁盤機(jī),P2先使用磁盤機(jī)后使用打印機(jī)。如果P2先提出資源請(qǐng)求,則P2只能先申請(qǐng)打印機(jī)(編號(hào)?。缓笊暾?qǐng)磁盤機(jī)(編號(hào)大)。P2在使用磁盤機(jī)的時(shí)候,打印機(jī)空閑著不能被P1申請(qǐng)使用3.6.3死鎖的避免避免死鎖的方法通過(guò)資源分配之前預(yù)測(cè)是否會(huì)導(dǎo)致死鎖,決定是否進(jìn)行此次資源分配。系統(tǒng)的兩種狀態(tài):安全狀態(tài)和不安全狀態(tài)

按某種順序并發(fā)進(jìn)程都能達(dá)到獲得最大資源而順序完成的序列為安全序列。能找到安全序列的狀態(tài)為安全狀態(tài)。若系統(tǒng)找不到這個(gè)安全序列則處于不安全狀態(tài)。安全狀態(tài)實(shí)例系統(tǒng)有三個(gè)進(jìn)程P1、P2和P3,共有14臺(tái)打印機(jī);進(jìn)程P1、P2和P3要求12臺(tái)、4臺(tái)和9臺(tái)打印機(jī)。假設(shè)T0時(shí)刻,進(jìn)程P1、P2和P3已經(jīng)獲得5臺(tái)、2臺(tái)和4臺(tái)打印機(jī)。進(jìn)程最大需求已分配還需要可用P112573P2422P3945安全序列:P2P3P1安全狀態(tài)向不安全狀態(tài)上例中,若P1再申請(qǐng)一臺(tái),則變?yōu)椴话踩珷顟B(tài)。進(jìn)程最大需求已分配還需要可用P112662P2422P3945利用銀行家算法避免死鎖1.?dāng)?shù)據(jù)結(jié)構(gòu)Resource[j]=k:系統(tǒng)Rj類資源一共有k個(gè);Available[j]=k:系統(tǒng)現(xiàn)有Rj類資源k個(gè);Claim[i,j]=k:進(jìn)程i需要Rj的最大數(shù)k個(gè);Alloction[i,j]=k:進(jìn)程i已得到Rj類資源k個(gè);Need[i,j]=k: 進(jìn)程i需要Rj類資源k個(gè)有:Need[i,j]=Claim[i,j]-Alloction[i,j]設(shè)Requesti是進(jìn)程i請(qǐng)求資源數(shù)worki:進(jìn)程i執(zhí)行完后系統(tǒng)應(yīng)有資源數(shù)(也即可用數(shù))Finish[i]:布爾量,表進(jìn)程i能否順序完成。銀行家算法Requesti≤Needi出錯(cuò)Requesti≤Availablei阻塞Available=Available-RequestiAlloctioni=Alloctioni+RequestiNeedi=Needi-RequestiFinish[j]=.F.Needj<=WorkWork=Work+AlloctionjFinish[j]=.T.否否是是舉例

ClaimR1R2R3AllocationR1R2R3

NeedR1R2R3

AvailableR1R2R3P1322100

P2613612P3314211P4422002假定系統(tǒng)中有四個(gè)進(jìn)程P1,P2,P3,P4和三類資源R1,R2,R3,每一種資源的數(shù)量分別為9、3、6,T0時(shí)刻的資源分配情況如下表。22

2001103420011T0時(shí)刻的安全序列<P2,P1,P4,P

溫馨提示

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

評(píng)論

0/150

提交評(píng)論