




版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、 實驗三:進程同步實驗一、實驗任務:(1)掌握操作系統(tǒng)的進程同步原理;(2)熟悉linux的進程同步原語;(3)設計程序,實現(xiàn)經(jīng)典進程同步問題。二、實驗原理:(1)P、V操作PV操作由P操作原語和V操作原語組成(原語是不可中斷的過程),對信號量進行操作,具體定義如下:P(S):將信號量S的值減1,即S=S-1;如果S³0,則該進程繼續(xù)執(zhí)行;否則該進程置為等待狀態(tài),排入等待隊列。V(S):將信號量S的值加1,即S=S+1;如果S>0,則該進程繼續(xù)執(zhí)行;否則釋放隊列中第一個等待信號量的進程。(2)信號量信號量(semaphore)的數(shù)據(jù)結(jié)構為一個值和一個指針,指針指向等待該信號量的
2、下一個進程。信號量的值與相應資源的使用情況有關。當它的值大于0時,表示當前可用資源的數(shù)量;當它的值小于0時,其絕對值表示等待使用該資源的進程個數(shù)。注意,信號量的值僅能由PV操作來改變。一般來說,信號量S³0時,S表示可用資源的數(shù)量。執(zhí)行一次P操作意味著請求分配一個單位資源,因此S的值減1;當S<0時,表示已經(jīng)沒有可用資源,請求者必須等待別的進程釋放該類資源,它才能運行下去。而執(zhí)行一個V操作意味著釋放一個單位資源,因此S的值加1;若S£0,表示有某些進程正在等待該資源,因此要喚醒一個等待狀態(tài)的進程,使之運行下去。(3)linux的進程同步原語wait();阻塞父進程,子
3、進程執(zhí)行;#include <sys/types.h>#include <sys/ipc.h>key_t ftok (char*pathname, char proj);它返回與路徑pathname相對應的一個鍵值。int semget(key_t key, int nsems, int semflg) 參數(shù)key是一個鍵值,由ftok獲得,唯一標識一個信號燈集,用法與msgget()中的key相同;參數(shù)nsems指定打開或者新創(chuàng)建的信號燈集中將包含信號燈的數(shù)目;semflg參數(shù)是一些標志位。參數(shù)key和semflg的取值,以及何時打開已有信號燈集或者創(chuàng)建一個新的信號燈
4、集與msgget()中的對應部分相同。該調(diào)用返回與健值key相對應的信號燈集描述字。調(diào)用返回:成功返回信號燈集描述字,否則返回-1。int semop(int semid, struct sembuf *sops, unsigned nsops); semid是信號燈集ID,sops指向數(shù)組的每一個sembuf結(jié)構都刻畫一個在特定信號燈上的操作。nsops為sops指向數(shù)組的大小。int semctl(int semid,int semnum,int cmd,union semun arg) 該系統(tǒng)調(diào)用實現(xiàn)對信號燈的各種控制操作,參數(shù)semid指定信號燈集,參數(shù)cmd指定具體的操作類型;參數(shù)s
5、emnum指定對哪個信號燈操作,只對幾個特殊的cmd操作有意義;arg用于設置或返回信號燈信息。三、實驗源程序:#include<sys/types.h>#include<sys/ipc.h>#include<sys/sem.h>#include<errno.h>#include<stdlib.h>#include<stdio.h>#include<ftl.h>#include<unistd.h>#include <string.h>#include <sys/stat.h>
6、#include <sys/types.h>#include <sys/ipc.h>#include <sys/shm.h>#define PERM S_IRUSR|S_IWUSR#define SEMKEY (key_t)0x200typedef union _senum int val; struct semid_ds *buf; ushort *array;semun;int semid;static int count=0;FILE *fp,*fp1,*fp2;struct sembuf prmutex=0,-1,0,pwmutex=1,-1,0,p
7、s=2,-1,0;struct sembuf vrmutex=0,1,0,vwmutex=1,1,0,vs=2,1,0;int initsem() semun x; x.val=1; if(semid=semget(SEMKEY,3,0600|IPC_CREAT|IPC_EXCL)=-1) if(errno=EEXIST) semid=semget(SEMKEY,3,0); if(semctl(semid,0,SETVAL,x)=-1) perror("semctl failedn"); return(-1); if(semctl(semid,1,SETVAL,x)=-1)
8、 perror("semctl failedn"); return(-1); if(semctl(semid,2,SETVAL,x)=-1) perror("semctl failedn"); return(-1); return(semid);main() int i,j,k; static int a30; int shmid; int *pint,*pint2,addr,addr2; for(i=0;i<30;i+) ai=i; if(shmid=shmget(IPC_PRIVATE,4,PERM)=-1) fprintf(stderr,&q
9、uot;Create Share Memory Error:%sna",strerror(errno);exit(1); addr=shmat(shmid,0,0) ; pint=(int*)addr; *pint=0; semid=initsem(); if(fork()=0) /writer semop(semid,&pwmutex,1); printf("call writern"); fp1=fopen("a.txt","w"); for(k=0;k<20;k+) fprintf(fp1,"%
10、dn ",5*k); printf("write %dn ",5*k); fclose(fp1); printf("write finish!n"); semop(semid,&vwmutex,1); exit(0); else if(fork()=0) /reader 1 semop(semid,&prmutex,1); addr2=shmat(shmid,0,0); pint2=(int*)addr2; if(*pint2=0) semop(semid,&pwmutex,1); *pint2=*pint2+1; pr
11、intf("reader 1 enter- count=%dn",*pint2); semop(semid,&vrmutex,1); fp=fopen("a.txt","r"); while(!feof(fp) fscanf(fp,"%d ",&i); printf("reader 1 %dn ",i); semop(semid,&prmutex,1); *pint2=*pint2-1; printf("reader 1 exit- count=%dn"
12、;,*pint2); /count=count-1; /printf("count=%dn",count); if(*pint2=0) semop(semid,&vwmutex,1); semop(semid,&vrmutex,1); exit(0); else if(fork()=0) /reader semop(semid,&prmutex,1); addr2=shmat(shmid,0,0); pint2=(int*)addr2; if(*pint2=0) semop(semid,&pwmutex,1); *pint2=*pint2+1
13、; printf("Read 2 enter+ count=%dn",*pint2); / printf("Read 2 count=%dn",count); /count=2; /printf("count=%dn",count); semop(semid,&vrmutex,1); fp=fopen("a.txt","r"); while(!feof(fp) fscanf(fp,"%d ",&i); printf("reader 2 %dn ",i); semop(semid,&prmutex,1); /count=count-1
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 乳品工藝技術創(chuàng)新與發(fā)展考核試卷
- 勘察項目項目管理氣候變化與勘察應對策略考核試卷
- 批發(fā)市場的產(chǎn)品陳列與促銷技巧考核試卷
- 施工監(jiān)督與試車開車中安全注意事項考核試卷
- 小學生天氣安全教育課件
- 農(nóng)田土壤售賣合同范本
- 個人產(chǎn)品交易合同范本
- 玻璃浴房合同范本
- 委托裝修安全合同范本
- 礦供銷合同范本
- 吉利圍墻施工組織設計樣本
- 第6課《飛向藍天的恐龍》兩課時學習任務單部編版四年級語文下冊
- 大數(shù)據(jù)在人力資源管理中的應用案例
- 語文新課標背景下單元整體教學:六下第4單元大單元設計
- 福州地鐵公司招聘考試題目
- 2024-2025年美的集團財務報表分析
- 小學語文期末質(zhì)量分析報告
- 口腔醫(yī)院客服培訓課件
- 2023年大學日語四級考試試題答案
- 04G325吊車軌道聯(lián)結(jié)及車擋
- 髖關節(jié)滑膜炎護理課件
評論
0/150
提交評論