系統(tǒng)平臺(tái)實(shí)驗(yàn)7-線程同步與多線程編程

系統(tǒng)平臺(tái)實(shí)驗(yàn)7-線程同步與多線程編程

ID:14207460

大?。?3.00 KB

頁數(shù):6頁

時(shí)間:2018-07-26

系統(tǒng)平臺(tái)實(shí)驗(yàn)7-線程同步與多線程編程_第1頁
系統(tǒng)平臺(tái)實(shí)驗(yàn)7-線程同步與多線程編程_第2頁
系統(tǒng)平臺(tái)實(shí)驗(yàn)7-線程同步與多線程編程_第3頁
系統(tǒng)平臺(tái)實(shí)驗(yàn)7-線程同步與多線程編程_第4頁
系統(tǒng)平臺(tái)實(shí)驗(yàn)7-線程同步與多線程編程_第5頁
資源描述:

《系統(tǒng)平臺(tái)實(shí)驗(yàn)7-線程同步與多線程編程》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在行業(yè)資料-天天文庫

1、實(shí)驗(yàn)7線程同步與多線程編程一、實(shí)驗(yàn)?zāi)康耐ㄟ^本實(shí)驗(yàn)了解和掌握線程的相關(guān)知識(shí),使學(xué)生(1)了解系統(tǒng)中線程同步的基本原理。(2)了解和熟悉多線程編程及線程訪問控制。二、實(shí)驗(yàn)內(nèi)容1.生產(chǎn)者-消費(fèi)者問題用信號(hào)量實(shí)現(xiàn)生產(chǎn)者-消費(fèi)者問題。分析:信號(hào)量的考慮這里使用3個(gè)信號(hào)量,其中兩個(gè)信號(hào)量empty和full分別用于解決生產(chǎn)者和消費(fèi)者線程之間的同步問題,mutex是用于這兩個(gè)線程之間的互斥問題。其中empty初始化為N(緩沖區(qū)的單元數(shù)),mutex初始化為1,full初始化為0。程序流程如下:1)開始->建立有名管道->打開有名管道->初始化3個(gè)信號(hào)量->創(chuàng)建消費(fèi)者和生產(chǎn)者兩個(gè)線程。2)生產(chǎn)者線程。wa

2、it操作(empty)->wait操作(mutex)->寫管道->signal操作(full)->signal操作(mutex)。3)消費(fèi)者線程。請(qǐng)自己實(shí)現(xiàn)。源代碼:exp71.c#include#include#include#include#include#include#include#include#include#include#defineFIFO"myfifo"#defineN5

3、intlock_var;time_tend_time;charbuf_r[100];定義buf_r數(shù)組表示緩沖區(qū)sem_tmutex,full,empty;互斥信號(hào)量木特性,信號(hào)量empty表示緩沖池中空幻吃區(qū)適量,full表示滿緩沖區(qū)適量intfd;voidproducer(void*arg);voidconsumer(void*arg);6intmain(intargc,char*argv[]){pthread_tid1,id2;pthread_tmon_th_id;intret;end_time=time(NULL)+10;創(chuàng)建管道if((mkfifo(FIFO,0777

4、O_CRE

5、AT)<0)&&(errno!=EEXIST))printf("cannotcreatfifoserver");printf("Preparingforreadingbytes");memset(buf_r,0,sizeof(buf_r));打開管道fd=open(FIFO,O_RDWR

6、O_NONBLOCK,0);if(fd==-1){perror("open");exit(1);}初始化互斥信號(hào)和emptyfull緩沖區(qū)ret=sem_init(&mutex,0,1);ret=sem_init(&empty,0,N);ret=sem_init(&full,0,0);if(ret

7、!=0){perror("sem_init");}ret=pthread_create(&id1,NULL,(void*)producer,NULL);創(chuàng)建生產(chǎn)者線程創(chuàng)建成功返回0if(ret!=0)perror("pthreadcreate1");ret=pthread_create(&id2,NULL,(void*)consumer,NULL);創(chuàng)建消費(fèi)者線程創(chuàng)建成功返回0.if(ret!=0)perror("pthreadcreate2");pthread_join(id1,NULL);等待生產(chǎn)者線程結(jié)束pthread_join(id2,NULL);等待消費(fèi)者縣城結(jié)束exit(0);

8、}voidproducer(void*arg){inti,nwrite;while(time(NULL)

9、mutex);sleep(1);}}voidconsumer(void*arg){Intnwrite;While(time(NULL)

當(dāng)前文檔最多預(yù)覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當(dāng)前文檔最多預(yù)覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學(xué)公式或PPT動(dòng)畫的文件,查看預(yù)覽時(shí)可能會(huì)顯示錯(cuò)亂或異常,文件下載后無此問題,請(qǐng)放心下載。
2. 本文檔由用戶上傳,版權(quán)歸屬用戶,天天文庫負(fù)責(zé)整理代發(fā)布。如果您對(duì)本文檔版權(quán)有爭議請(qǐng)及時(shí)聯(lián)系客服。
3. 下載前請(qǐng)仔細(xì)閱讀文檔內(nèi)容,確認(rèn)文檔內(nèi)容符合您的需求后進(jìn)行下載,若出現(xiàn)內(nèi)容與標(biāo)題不符可向本站投訴處理。
4. 下載文檔時(shí)可能由于網(wǎng)絡(luò)波動(dòng)等原因無法下載或下載錯(cuò)誤,付費(fèi)完成后未能成功下載的用戶請(qǐng)聯(lián)系客服處理。