




版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
進(jìn)程與線程—Linux進(jìn)程與線程通訊設(shè)計(jì)目的深刻理解線程和進(jìn)程的概念,掌握線程與進(jìn)程在構(gòu)成成分上的差異以及與其相適應(yīng)的通訊方式和應(yīng)用目的。設(shè)計(jì)的內(nèi)容1、以Linux系統(tǒng)進(jìn)程和線程機(jī)制為背景,掌握f(shuō)ork()和clone()系統(tǒng)調(diào)用的2、形式和功能以及與其相適應(yīng)的高級(jí)通訊方式。由fork派生的子進(jìn)程之間通過(guò)pipe通訊,由clone創(chuàng)立的線程之間通過(guò)共享內(nèi)存通訊,對(duì)于后者需要考慮互斥問(wèn)題。3、以生產(chǎn)者-消費(fèi)者問(wèn)題為例,通過(guò)試驗(yàn)理解fork()和clone()兩個(gè)系統(tǒng)調(diào)用的區(qū)別。程序規(guī)定可以創(chuàng)立4個(gè)進(jìn)程或線程,其中包括兩個(gè)生產(chǎn)者和兩個(gè)消費(fèi)者,生產(chǎn)者和消費(fèi)者之間可以傳遞數(shù)據(jù)。三、設(shè)計(jì)準(zhǔn)備1、fork系統(tǒng)調(diào)用、pid=fork()創(chuàng)立一種子進(jìn)程,子進(jìn)程是父進(jìn)程的完整復(fù)制,正常返回值為非負(fù)整數(shù),對(duì)于父進(jìn)程來(lái)說(shuō)該數(shù)不小于0,是子進(jìn)程的編號(hào)(pid);對(duì)于子進(jìn)程來(lái)說(shuō)該數(shù)為0。正是運(yùn)用反回值的差異可以決定兩者不一樣的后繼動(dòng)作。2、clone系統(tǒng)調(diào)用intclone(int(*fn)(void*arg),void*stack,intflags,void*arg);其中fn是輕進(jìn)程所執(zhí)行的函數(shù),stack是輕進(jìn)程所使用的棧,flag是CLONE_VM,CLONE_FS,CLONE_FILES,LONE_SIGHAND,CLONE_PID的組合,arg是調(diào)用過(guò)程的對(duì)應(yīng)參數(shù)。Clone()的關(guān)鍵是flag的設(shè)定,CLONE_VM表達(dá)子進(jìn)程共享父進(jìn)程內(nèi)存,CLONE_FS表達(dá)子進(jìn)程共享父進(jìn)程的文獻(xiàn)系統(tǒng),CLONE_SIGHAND表達(dá)子進(jìn)程共享父進(jìn)程的消息處理機(jī)制,CLONE_PID是指子進(jìn)程繼承父進(jìn)程的id號(hào)。3、pipe系統(tǒng)調(diào)用ret_val=pipe(fd);參數(shù)定義為intfd[2]。創(chuàng)立一種管道文獻(xiàn),返回兩個(gè)文獻(xiàn)描述符fd[0]和fd[1]分別用于管道文獻(xiàn)的讀和寫(xiě)操作。管道文獻(xiàn)創(chuàng)立后,可以被fork創(chuàng)立的子進(jìn)程共享。4、sem_wait(&s)和sem_post(&s)分別相稱(chēng)于信號(hào)燈的P操作和V操作。其中s是闡明為sem_t類(lèi)型的信號(hào)燈。初始化函數(shù)sem_init(s,0,8)。5、pthread_mutex_lock(&mutex)和pthread_mutex_unlock(&mutex)分別用于加鎖和解鎖。參數(shù)為pthread_mutex_tmutex定義的互斥鎖。初始化tthread_mutex_init(&mutex,NULL)。四、試驗(yàn)設(shè)計(jì)1、用pipe()創(chuàng)立一種管道文獻(xiàn)2、然后用fork()創(chuàng)立兩個(gè)生產(chǎn)進(jìn)程和兩個(gè)消費(fèi)進(jìn)程3、它們之間通過(guò)pipe()傳遞信息4、用clone()創(chuàng)立四個(gè)輕進(jìn)程(線程)5、用參數(shù)指明共享內(nèi)存等資源6、通過(guò)共享內(nèi)存模擬生產(chǎn)消費(fèi)問(wèn)題7、運(yùn)用pthread_mutex_lock(),pthread_mutex_unlock()等函數(shù)實(shí)現(xiàn)對(duì)共享存儲(chǔ)區(qū)訪問(wèn)的互斥五、程序流程5.1基于fork的程序流程5.2基于clone的程序流程六、成果輸出及分析1、基于fork的成果輸出分析:由程序(1)成果可見(jiàn),當(dāng)一種進(jìn)程變化其空間數(shù)據(jù)時(shí),其他進(jìn)程空間對(duì)應(yīng)數(shù)據(jù)內(nèi)容并未變化,闡明在使用fork()語(yǔ)句創(chuàng)立的子進(jìn)程與其父進(jìn)程具有相對(duì)獨(dú)立的地址空間,在處理生產(chǎn)消費(fèi)的問(wèn)題時(shí),可以采用pipe()進(jìn)行通信。由于子進(jìn)程復(fù)制了父進(jìn)程的打開(kāi)文獻(xiàn)表,因此pipe()所建立的通信管道可被子進(jìn)程繼承,生產(chǎn)和消費(fèi)進(jìn)程可以通過(guò)對(duì)同一管道文獻(xiàn)的讀寫(xiě)進(jìn)行通訊。程序(1)中,消費(fèi)者從管道中接受生產(chǎn)者發(fā)送的數(shù)據(jù),并且和自己存儲(chǔ)區(qū)中的數(shù)據(jù)進(jìn)行比較,兩者的數(shù)據(jù)是不一樣的,闡明兩個(gè)進(jìn)程擁有不一樣的存儲(chǔ)空間。2、基于clone()的成果輸出分析:由程序(2)成果可見(jiàn),clone()語(yǔ)句在創(chuàng)立進(jìn)程時(shí),可通過(guò)參數(shù)設(shè)定子進(jìn)程與父進(jìn)程與否共享存儲(chǔ)空間,從而可以創(chuàng)立真正意義上的線程。生產(chǎn)者和消費(fèi)者進(jìn)程共享內(nèi)存,從而可以通過(guò)共享內(nèi)存直接互換數(shù)據(jù)。不過(guò)多種進(jìn)程共享內(nèi)存需要互斥機(jī)制,程序中定義了臨界區(qū)變量mutex和兩個(gè)信號(hào)量product,warehouse,臨界區(qū)變量用于共享內(nèi)存操作的互斥,信號(hào)量分別實(shí)現(xiàn)了生產(chǎn)者和消費(fèi)者的等待。程序(2)中,消費(fèi)者輸出存儲(chǔ)區(qū)中的數(shù)據(jù),并且存儲(chǔ)區(qū)中的數(shù)據(jù)伴隨生產(chǎn)者存入的數(shù)據(jù)而發(fā)生變化,闡明clone()語(yǔ)句通過(guò)flag的設(shè)定實(shí)現(xiàn)了共享內(nèi)存。若在試驗(yàn)中除去CLONE_VM選項(xiàng),將出現(xiàn)非預(yù)期的成果。七、參照文獻(xiàn)[1]計(jì)算機(jī)操作系統(tǒng)教程左萬(wàn)歷周長(zhǎng)林編著高等教育出版社.9[2]操作系統(tǒng)教程孫鐘秀高等教育出版社.07[3]計(jì)算機(jī)操作系統(tǒng)湯子瀛哲鳳屏湯小丹[4]操作系統(tǒng)習(xí)題與試驗(yàn)指導(dǎo)左萬(wàn)歷焦素云高等教育出版社[5]嵌入式Linux應(yīng)用程序開(kāi)發(fā)原則教程(第2版)人民郵電出版社[6]《ProgrammingWindows程式開(kāi)發(fā)設(shè)計(jì)指南》CharlesPetzold.06附錄(1)基于fork()系統(tǒng)調(diào)用代碼實(shí)現(xiàn)#include"sys/types.h"#include"sys/file.h"#include"unistd.h"#include<stdio.h>#include<stdlib.h>charr_buf[4];//讀緩沖charw_buf[4];//寫(xiě)緩沖intpipe_fd[2];pid_tpid1,pid2,pid3,pid4;intproducer(intid);intconsumer(intid);intmain(intargc,char**argv){if(pipe(pipe_fd)<0){printf("pipecreateerror\n");exit(-1);}else{printf("pipeiscreatedsuccessfully!\n");if((pid1=fork())==0)producer(1);if((pid2=fork())==0)producer(2);if((pid3=fork())==0)consumer(1);if((pid4=fork())==0)consumer(2);}close(pipe_fd[0]);close(pipe_fd[1]);inti,pid,status;for(i=0;i<4;i++)pid=wait(&status);exit(0);}intproducer(intid){printf("producer%disrunning!\n",id);close(pipe_fd[0]);inti=0;for(i=1;i<10;i++){sleep(3); if(id==1)strcpy(w_buf,"aaa\0");else//生產(chǎn)者2strcpy(w_buf,"bbb\0");if(write(pipe_fd[1],w_buf,4)==-1)printf("writetopipeerror\n"); }close(pipe_fd[1]);printf("producer%disover!\n",id);exit(id);}intconsumer(intid){close(pipe_fd[1]);printf("producer%disrunning!\n",id);if(id==1)strcpy(w_buf,"ccc\0");else//消費(fèi)者2strcpy(w_buf,"ddd\0");while(1){sleep(1); strcpy(r_buf,"eee\0"); if(read(pipe_fd[0],r_buf,4)==0)break; printf("consumer%dget%s,whilethew_bufis%s\n",id,r_buf,w_buf);}close(pipe_fd[0]);printf("consumer%disover!\n",id);exit(id);}(2)基于clone()系統(tǒng)調(diào)用代碼實(shí)現(xiàn)#include"sched.h"#include"pthread.h"#include"stdio.h"#include"stdlib.h"#include"semaphore.h"intproducer(void*args);intconsumer(void*args);pthread_mutex_tmutex;sem_tproduct;sem_twarehouse;charbuffer[8][4];intbp=0;main(intargc,char**argv){pthread_mutex_init(&mutex,NULL);sem_init(&product,0,0);sem_init(&warehouse,0,8);intclone_flag,arg,retval;char*stack;clone_flag=CLONE_VM|CLONE_SIGNAND|CLONE_FS|CLONE_FILES;inti;for(i=0;i<2;i++){arg=i;stack=(char*)malloc(4096);retval=clone((void*)producer,&(stack[4095]),clone_flag,(void*)&arg);stack=(char*)malloc(4096);retval=clone((void*)consumer,&(stack[4095]),clone_flag,(void*)&arg);}exit(1);}intproducer(void*args){intid=*((int*)args);inti;for(i=0;i<10;i++){ sleep(i+1);sem_wait(&warehouse);pthread_mutex_lock(&mutex);if(id==0)strcpy(buffer[bp],"aaa\0");elsestrcpy(buffer[bp],"bbb\0");bp++;printf("producer%dproduce%sin%d\n",id,buffer[bp],bp-1);pthread_mutex_unlock(&mutex);sem_post(&product);}printf("producer%disover!\n",id);}intconsumer(void*args){intid=*((int*)args);inti;for(i=0;i<10;i++){sleep(10-i);//體現(xiàn)線程速度差異sem_wait(&p
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 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ì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度清潔能源投資意向協(xié)議合同
- 二零二五年度建筑工地施工現(xiàn)場(chǎng)安全員勞動(dòng)合同
- 二零二五年度股份轉(zhuǎn)讓與綠色低碳產(chǎn)業(yè)發(fā)展合作合同
- 二零二五年度科技競(jìng)賽專(zhuān)題片拍攝與播出協(xié)議
- 二零二五年度家常菜廚師雇傭合同樣本
- 2025年度網(wǎng)絡(luò)安全公司勞動(dòng)合同范本
- 2025年度診所執(zhí)業(yè)醫(yī)師醫(yī)療質(zhì)量監(jiān)控聘用合同
- 2025年度環(huán)保節(jié)能技術(shù)改造股權(quán)合作協(xié)議
- 二零二五年度合伙美發(fā)店?duì)I銷(xiāo)合作合同協(xié)議
- 2025年度高校畢業(yè)生就業(yè)協(xié)議書(shū)官方范本
- 中國(guó)聯(lián)通IMS接口規(guī)范 第三分冊(cè):Sh接口 V1.0
- protel完全教程(原理圖部分)
- 環(huán)境化學(xué)物的毒性作用及其影響因素
- Q∕GDW 12176-2021 反竊電監(jiān)測(cè)終端技術(shù)規(guī)范
- 判斷抽樣(課堂PPT)
- 簡(jiǎn)明疼痛評(píng)估量表(BPI)
- QUY400t性能表履帶起重機(jī)
- 通用橫版企業(yè)報(bào)價(jià)單模板
- 國(guó)際網(wǎng)聯(lián)ITF教練員標(biāo)準(zhǔn)教材(共13頁(yè))
- 中國(guó)移動(dòng)B-BOSS系統(tǒng)總體結(jié)構(gòu)
- 人教版三年級(jí)下冊(cè)數(shù)學(xué)試卷5套
評(píng)論
0/150
提交評(píng)論