《操作系統(tǒng) 作業(yè)答案》由會員分享,可在線閱讀,更多相關《操作系統(tǒng) 作業(yè)答案(7頁珍藏版)》請在裝配圖網上搜索。
1、第九題 設有兩個生產者進程A、B和一個銷售者進程C,他們共享一個無限大的倉庫,生產者每次循環(huán)生產一個產品,然后入庫供銷售;銷售者每次循環(huán)從倉庫中取出一個產品進行銷售。如果不允許同時入庫,也不允許邊入庫邊出庫;而且要求生產和消費A產品和B產品的件數都滿足以下關系:-n≤A的件數-B的件數≤m,其中n、m是正整數。
分析:生產者A、B和消費者之間不能同時將產品入庫和出庫,故倉庫是一個臨界資源。
生產的A、B產品必須滿足:-n≤A的件數-B的件數≤m,如練習5中,同樣的方法管理,分別使用了信號量SAB和SBA;
倉庫的管理只要求出入庫互斥,由于倉庫無限大入庫只需操作互斥就可以完成,出庫要
2、考慮有無產品,SA對應于倉庫中的A產品量,SB對應于倉庫中的B產品量;
銷售要滿足:-n≤A的件數-B的件數≤m,用difference表示A的件數-B的件數,即difference= A的件數-B的件數;difference==-n的時候,不能取產品B,只能取A;difference==m的時候,不能取產品A,只能取B;-n
3、BA表示當前允許B生產的產品數量,其初值為n;另外,還需設置一個整數difference表示所銷售的A、B產品數量之差,而為了同步生產者和銷售者并使銷售的A、B產品的件數-n≤A的件數-B的件數≤m,還需要設置三個資源信號量,其中S對應于倉庫中的總的產品量,SA對應于倉庫中的A產品量,SB對應于倉庫中的B產品量,它們的初值都為0.
Semaphore SAB=m,SBA=n,S=0,SA=0,SB=0,mutex=1;
process A( )
{ while(1)
{//生產產品,-n≤A的件數-B的件數≤m,方法同第4題
wait(SAB);
Produce a produ
4、ct A;
signal(SBA);
//入庫操作,滿足出入庫操作互斥即可
wait(mutex);
add the product A to the storehouse;
signal(mutex);
signal(SA); //入庫產品A一件,所以給SA增值
signal((S); //入庫產品一件,所以給S增值,S是倉庫中全部產品的數量
}
}
process B( )
{ while(1)
{//生產產品,-n≤A的件數-B的件數≤m,方法同第4題
wait(SBA);
Produce a product B;
signal(SAB);
5、
//入庫操作,滿足出入庫操作互斥即可
wait(mutex);
add the product A to the storehouse;
signal(mutex);
signal(SB); //入庫產品A一件,所以給SA增值
signal((S); //入庫產品一件,所以給S增值,S是倉庫中全部產品的數量
}
}
process C( )
{ while(1)
{ wait(S); //首先檢查有無產品,無產品阻塞,有產品,下面操作將會取走一件產品,所以S減1
if(difference<=-n)
{wait(SA); // diffe
6、rence<=-n時只能取A產品一件,無A產品則需阻塞
//出庫操作,滿足出入庫操作互斥
wait(mutex);
take a product A from storehouse;
signal(mutex);
difference++; //取A產品一件,difference++
}
else if(difference>=m)
{ wait(SB); // difference>=m時只能取B產品一件,無B產品則需阻塞
//出庫操作,滿足出入庫操作互斥
wait(mutex);
take a product B
7、 from storehouse;
signal(mutex);
difference--; //取B產品一件,difference--
}
else
{ //-n
8、SA減1,這里不可能發(fā)生沒有A產品,進程C需要阻塞的情況
wait(SA);
difference++;//取A產品一件,difference++
}
else
{//取的是產品B,則信號量SB減1,這里不可能發(fā)生沒有B產品,進程C需要阻塞的情況
wait(SB);
difference--;//取B產品一件,difference--
}
}
Sell the product;
}
}
main()
{
cobegin{
A();
B();
C();
}
}
9、
例題20解答
本題是一個有限緩沖區(qū)的生產者消費者問題,關鍵是找到緩沖區(qū)資源,以及誰是生產者、誰是消費者。
本題中煙草、紙和火柴應該看作是產品,桌子是緩沖區(qū)。問題是有幾種產品。煙草、紙和火柴三種原料又不能簡單地看成是三種產品,因為它們并不是以單獨的形式被三個吸煙者進程所競爭的,而是以固定的組合被三個進程所申請的。因此可以考慮:設置三個信號量r、s和t,分別代表三種原料組合,即r表示煙草和紙,s表示紙和火柴,t表示煙草和火柴,初值均為0;桌面上一次只能放一種組合,可以看作是放一個產品的緩沖區(qū),設置信號量empty初值為1,控制經銷商往桌子上放原料;對于三個吸煙者的申請動作也要加以
10、判斷,用三個變量smoker1、smoker2、smoker3,初值為false,當為true時,表示申請資源,得到資源后置為false。四個進程循環(huán)往復,并發(fā)執(zhí)行。
經銷商進程:
吸煙者1進程:?
吸煙者2進程:?
吸煙者3進程:
第一題44. a、b兩點之間是一段東西向的單行車道,現要設計一個自動管理系統(tǒng),管理規(guī)則如下:當a、b之間有車輛在行駛時同方向的車可以同時駛入ab段,但另一方向的車必須在ab段外等待;當ab之間無車輛在行駛時,到達a點(或b點)的車輛可以進入ab段,但不能從a點和b點同時駛入;當某方向在ab段駛出
11、了ab段且暫無車輛進入ab段時,應讓另一方向等待的車輛進入ab段行駛。
現定義兩個計數器CountE和CountW分別記錄東行和西行車輛進程數。用PV操作進行管理時的三個信號量為S、SE、SW,程序結構如下:
begin
S, SE, SW: semaphore;
CountE, CountW: Integer;
CountE := ____(1)_0___; CountW := ____(2)_0___;
S := ____(3)_1___; SE := ____(4)_1___; SW := ____(5)1____;
cobegin
P
12、rocess EASTi (i=1, 2, 3, …)
begin
____(6)_P(SE)___;
if CountE = 0 then____(7)P(S)____;
CountE := CountE+1;
____(8)_V(SE)___;
pass(ab);
____(9)_P(SE)___;
CountE := CountE-1;
if CountE = 0 then ____(10)_V(S)___;
____(11)_V(SE)___;
end;
Process WEST
13、j(j=1, 2, 3, …)
Begin
____(12)_P(SW)___;
if CountW = 0 then ____(13)_P(S)___;
CountW := CountW+1;
____(14)_V(SW)___;
pass(ba);
____(15)_P(SW)___;
CountW := CountW-1;
if CountW = 0 then ____(16)_V(S)___;
____(17)_V(SW)___;
end;
coend;
end;
44.
14、 (1) 0 (2) 0 (3) 1 (4) 1 (5) 1 (6) P(SE) (7) P(S) (8) V(SE) (9) P(SE) (10) V(S)
(11) V(SE) (12) P(SW) (13) P(S) (14) V(SW) (15) P(SW) (16) V(S) (17) V(SW)
3、如果有三個進程R、W1、W2共享一個緩沖器B,而B中每次只能存放一個數。當緩沖器中無數時,進程R可以將從輸入設備上讀入的數存放到緩沖器中。若存放到緩沖器中的是奇數,則允許進程W1將其取出打?。蝗舸娣诺骄彌_器中的是偶數,則允許進程W2將其取出
15、打印。同時規(guī)定:進程R必須等緩沖區(qū)中的數被取出打印后才能再存放一個數;進程W1或W2對每次存入緩沖器的數只能打印一次;W1和W2都不能從空緩沖中取數。寫出這三個并發(fā)進程能正確工作的程序。
答:S為互斥信號量,用來對緩沖器的互斥使用;
SO和SE為資源信號量,SO表示是否允許進程W1打印;SE表示是否允許進程W2打印。
semaphore S=1,SO=SE=0;
buffer B;
process R()
{ int x;
while(1)
{從輸入設備上讀一個數;
x=接收的數;
wait(S);
B=x;
if B=奇數 then signal(SO);
else signal(SE); }
}
process W1()
{ int y;
while(1)
{ wait(SO);
y=B;
signal(S);
打印y中數;}
}
process W2()
{ int z;
while(1)
{ wait(SE);
z=B;
signal(S);
打印z中數 ;}
}
main()
{cobegin
{ R();
W1();
W2();}
}