版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上實驗二 體驗Nachos下的并發(fā)程序設(shè)計一、實驗人員: 二、實驗?zāi)康模簩崿F(xiàn)Nachos的同步機制:鎖和條件變量,并利用這些同步機制實現(xiàn)一些工具類。三、實驗內(nèi)容:1.實現(xiàn)鎖機制和條件變量2.實現(xiàn)一個線程安全的表結(jié)構(gòu)3.實現(xiàn)一個大小受限的緩沖區(qū)四、實驗步驟:1.實現(xiàn)鎖機制和條件變量1.1用Thread:Sleep實現(xiàn)鎖機制和條件變量相關(guān)代碼:Synch-sleep.h#include copyright.h #include thread.h #include list.h #include system.h class Lockpublic: Lock(char* de
2、bugName); /initialize lock be FREE Lock(); char* getName() return name; /debugging assist void Acquire(); /wait until the lock is FREE, then set it to BUSY void Release(); /set lock to be FREE, waking up a thread waiting /in Acquire if necessary bool isHeldByCurrentThread(); / true if the current th
3、read / holds this lock. Useful for checking in Release, and in / Condition variable ops below private: char* name; Thread *LockedThread; bool LockValue; List *queue; class Condition public: Condition(char* debugName); /initialize condition to no one waiting Condition();/析構(gòu)函數(shù) char* getName() return n
4、ame; void Wait(Lock *conditionLock); /release the lock, relinquish the CPU until signaled,then re-acquire the lock void Signal(Lock *conditionLock); /wake up a thread, if there are any waiting on the condition void Broadcast(Lock *conditionLock); /wake up all threads waiting on the condition private
5、: char* name; List *queue; Synch-sleep.cc#include copyright.h#include system.h#include thread.h#include list.h#include synch-sleep.hLock:Lock(char* debugName) /initialize lock be FREE name = debugName; queue = new List; LockedThread = new Thread(LockedThread); LockValue = 0; Lock:Lock() /析構(gòu)函數(shù) delete
6、 queue; delete LockedThread; void Lock:Acquire() /wait until the lock is FREE, then set it to BUSY IntStatus oldLevel = interrupt-SetLevel(IntOff); while ( LockValue ) queue-Append(void *)currentThread); /put currentThread at the end of the list currentThread-Sleep(); LockedThread = currentThread; L
7、ockValue = 1; (void) interrupt-SetLevel(oldLevel); void Lock:Release() /set lock to be FREE, waking up a thread waiting in Acquire if necessary Thread *thread; ASSERT( isHeldByCurrentThread() ); IntStatus oldLevel = interrupt-SetLevel(IntOff); LockedThread = NULL; thread = (Thread *)queue-Remove();
8、if ( thread != NULL ) scheduler-ReadyToRun(thread);LockValue=false; (void) interrupt-SetLevel(oldLevel); bool Lock:isHeldByCurrentThread() / true if the current thread holds this lock. Useful for checking in Release, /and in Condition variable ops below if ( LockedThread = currentThread & LockValue
9、) return true; else return false; Condition:Condition(char* debugName) /initialize condition to no one waiting name = debugName; queue = new List; Condition:Condition() /析構(gòu)函數(shù) delete queue; void Condition:Wait(Lock *conditionLock) /release the lock, relinquish the CPU until signaled,then re-acquire t
10、he lock ASSERT(conditionLock-isHeldByCurrentThread(); IntStatus oldLevel = interrupt-SetLevel(IntOff); queue-Append(void *)currentThread); conditionLock-Release(); currentThread-Sleep(); conditionLock-Acquire(); (void) interrupt-SetLevel(oldLevel); void Condition:Signal(Lock *conditionLock) /wake up
11、 a thread, if there are any waiting on the condition Thread *thread; ASSERT( conditionLock-isHeldByCurrentThread() ); IntStatus oldLevel = interrupt-SetLevel(IntOff); thread = (Thread *)queue-Remove(); if ( thread != NULL ) scheduler-ReadyToRun(thread); (void) interrupt-SetLevel(oldLevel); void Cond
12、ition:Broadcast(Lock* conditionLock) /wake up all threads waiting on the condition Thread *thread; ASSERT( conditionLock-isHeldByCurrentThread(); IntStatus oldLevel = interrupt-SetLevel(IntOff); thread = (Thread *)queue-Remove(); while ( thread != NULL ) scheduler-ReadyToRun(thread); thread = (Threa
13、d *)queue-Remove(); (void) interrupt-SetLevel(oldLevel); 1.2用Semaphore實現(xiàn)鎖機制和條件變量相關(guān)代碼:Synch-sem.h#ifndef SYNCH_SEM_H#define SYNCH_SEM_H#include copyright.h #include thread.h #include list.h class Semaphore public: Semaphore(char* debugName, int initialValue); /設(shè)置信號量初值 Semaphore(); /析構(gòu)函數(shù) char* getName
14、() return name; /debugging assist void P(); /waits until value 0, then decrement void V(); /increment, waking up a thread waiting in P() if necessary /均為原子操作 private: char *name; /useful for debugging int value; /信號量的值,均為非負(fù)的 List *queue; /threads waiting in P() for the value to be 0 ; class Lock pub
15、lic: Lock(char* debugName); /initialize lock to be FREE Lock(); /析構(gòu)函數(shù) char* getName() return name; /debugging assist void Acquire(); /wait until the lock is FREE, then set it to BUSY void Release(); /set lock to be FREE, waking up a thread waiting /均為原子操作 bool isHeldByCurrentThread(); / true if the
16、current thread / holds this lock. Useful for checking in Release, and in / Condition variable ops below. private: char* name; /for debugging Thread *LockedThread; bool LockValue; Semaphore *semaphore; int threadnum; ; class Condition public: Condition(char* debugName); /初始化條件變量為no one waiting Condit
17、ion(); /析構(gòu)函數(shù) char* getName() return name; /debugging assist void Wait(Lock *conditionLock); /release the lock, relinquish the CPU until signaled, /then re-acquire the lock /為原子操作 void Signal(Lock *conditionLock); /wake up a thread, /if there are any waiting on the condition void Broadcast(Lock *cond
18、itionLock); /wake up all threads waiting on the condition private: char* name; Semaphore *semaphore; int threadnum; ; #endifSynch-sem.cc#include copyright.h #include synch-sem.h #include system.h Semaphore:Semaphore(char* debugName, int initialValue) name = debugName; value = initialValue; queue = n
19、ew List; Semaphore:Semaphore() delete queue; void Semaphore:P() IntStatus oldLevel = interrupt-SetLevel(IntOff);/禁用中斷 while (value = 0) / semaphore not available queue-Append(void *)currentThread);/ so go to sleep currentThread-Sleep(); value-; / semaphore available, / consume its value (void) inter
20、rupt-SetLevel(oldLevel);/恢復(fù)中斷 void Semaphore:V() Thread *thread; IntStatus oldLevel = interrupt-SetLevel(IntOff);/禁用中斷 thread = (Thread *)queue-Remove(); if (thread != NULL) / make thread ready, consuming the V immediately scheduler-ReadyToRun(thread); value+; (void) interrupt-SetLevel(oldLevel);/恢復(fù)
21、中斷 Lock:Lock(char* debugName) /initialize lock to be FREE name = debugName; LockedThread = new Thread(LockedThread); LockValue = 0; threadnum = 0; semaphore = new Semaphore(locksem,0); Lock:Lock() /析構(gòu)函數(shù) delete LockedThread; delete semaphore; void Lock:Acquire() /wait until the lock is FREE, then set
22、 it to BUSY ASSERT(!isHeldByCurrentThread() ); /check the lock if FREE while ( LockValue ) semaphore-P(); LockedThread = currentThread; LockValue = 1; void Lock:Release() /set lock to be FREE, waking up a thread waiting ASSERT( isHeldByCurrentThread(); /check the lock if BUSY LockedThread = NULL; Lo
23、ckValue = 0; semaphore-V(); bool Lock:isHeldByCurrentThread()if(LockedThread=currentThread)&LockValue)return true;elsereturn false; Condition:Condition(char* debugName) /initialize condition to no one waiting name = debugName; semaphore = new Semaphore(Conditionsem,0); Condition:Condition() delete s
24、emaphore; void Condition:Wait(Lock* conditionLock) /release the lock, relinquish the CPU until signaled,then re-acquire the lock ASSERT( conditionLock-isHeldByCurrentThread(); /check the lock if held conditionLock-Release(); semaphore-P(); threadnum+; conditionLock-Acquire(); void Condition:Signal(L
25、ock *conditionLock) /wake up a thread,if there are any waiting on the condition ASSERT( conditionLock-isHeldByCurrentThread(); if ( threadnum 0 ) semaphore-V(); threadnum-; void Condition:Broadcast(Lock *conditionLock) /wake up all threads waiting on the condition ASSERT( conditionLock-isHeldByCurre
26、ntThread(); while ( threadnum 0 ) semaphore-V(); threadnum-; 1.4用鎖機制和條件變量修改雙向有序鏈表修改了dllist.h , dllist.cc,加入了鎖和條件鎖,為了方便測試,在threadtest.cc里加入一個變量flag,flag=0時不使用鎖,flag=1時使用鎖。修改部分主要為dllist.cc的Remove和SortedInsert函數(shù)void *DLList:Remove(int *keyPtr) / remove from head of listDLLElement *element;if(flag)lock-
27、Acquire();if (IsEmpty()if(flag) lock-Release();return NULL;void *retitem;element=first;*keyPtr=first-key;if (err_type=1)currentThread-Yield();retitem=element-item;if (first=last)first=NULL;last=NULL;elseif (err_type=1)currentThread-Yield();first=element-next;first-prev=NULL;delete element;if(flag)lo
28、ck-Release();return retitem;void DLList:SortedInsert(void *item, int sortKey) / routines to put/get items on/off list in order (sorted by key)DLLElement *insertItem=new DLLElement(item,sortKey);DLLElement *ptr=first;if(flag)lock-Acquire();if (IsEmpty()first=insertItem;if (err_type=2)currentThread-Yi
29、eld();last=insertItem;elsefor (;ptr!=NULL; ptr=ptr-next)if (ptr-keysortKey) break;if (err_type=3)currentThread-Yield();if (ptr=NULL)insertItem-prev=last;last-next=insertItem;last=insertItem;last-next=NULL;elseif (ptr=first)insertItem-next=first; first-prev=insertItem;first=insertItem;first-prev=NULL
30、;elseptr-prev-next=insertItem;insertItem-prev=ptr-prev;if (err_type=4)currentThread-Yield();insertItem-next=ptr;ptr-prev=insertItem;if(flag)lock-Release();2.實現(xiàn)一個線程安全的表結(jié)構(gòu)相關(guān)代碼:Table.h#include synch-sem.hclass Table public: / create a table to hold at most size entries. Table(int size); Table(); / allo
31、cate a table slot for object. / return the table index for the slot or -1 on error. int Alloc(int *object); / return the object from table index index or NULL on error. / (assert index is in range). Leave the table entry allocated / and the pointer in place. void *Get(int index); / free a table slot
32、 void Release(int index,int t); private: / Your code here. Lock *tablelock; int *table; int *value; int tablesize;/the size of the table;Table.cc#include Table.h #include thread.h#include system.hextern int flag;Table:Table(int size) / create a table to hold at most size entries. tablesize = size; t
33、ablelock = new Lock(Tablelock); table =new int*size;value =new intsize;for(int i=0;iAcquire(); for ( i=0; iYield(); tablei=object; valuei=1;if(flag) tablelock-Release();return i; if(flag) tablelock-Release(); return -1; void *Table:Get(int index) if ( index0 & indexAcquire(); if ( index=0 & indexRel
34、ease(); 3.實現(xiàn)一個大小受限的緩沖區(qū)相關(guān)代碼:BoudedBuffer.hclass BoundedBuffer public:BoundedBuffer();BoundedBuffer(); / create a bounded buffer with a limit of maxsize bytes void Read(char *data, int size,int t); / write size bytes from data into the bounded buffer. / (size may be greater than maxsize) void Write(ch
35、ar *data, int size,int t); private:int buffersize;Lock *bufferlock;Condition *bufferEmpty;Condition *bufferFull;char *buffer;int readout;int writein;int num;BoundedBuffer.cc#include copyright.h#include synch-sleep.h#include BoundedBuffer.h#include system.hextern int flag;BoundedBuffer:BoundedBuffer(
36、) bufferlock=new Lock(bufferlock); bufferEmpty=new Condition(readlist); bufferFull=new Condition(writelist);buffersize=10;buffer=new charbuffersize;readout=0;writein=0;num=0;BoundedBuffer:BoundedBuffer() delete bufferlock; delete bufferEmpty; delete bufferFull;delete buffer;void BoundedBuffer:Read(c
37、har *data,int size,int t)if(flag)bufferlock-Acquire();for(int i=0;iWait(bufferlock);i=0;elseprintf(the buffer is empty,cant read!n);return;elsedatai=bufferreadout;printf(n read buffer%d by thread %d,readout,t);num-;readout=(readout+1)%buffersize;if(flag)bufferFull-Broadcast(bufferlock);if(flag)buffe
38、rlock-Release();void BoundedBuffer:Write(char *data,int size,int t)if(flag)bufferlock-Acquire();for(int i=0;iWait(bufferlock);i=0;elseprintf(nbuffer is full cant write!);return;elsebufferwritein=datai;printf(n write buffer%d by thread %d,writein,t);writein=(writein+1)%buffersize;num+;if(flag)bufferE
39、mpty-Broadcast(bufferlock);if(flag)bufferlock-Release();4.修改threadtest.cc#include copyright.h#include system.h#include math.h#include thread.h#include stdio.h#include dllist.h#include Table.h#include BoundedBuffer.hint testnum = 1,threadnum=1,n,err_type=0,flag=0;DLList *dllist; Table *table;BoundedB
40、uffer *buffer;extern void Insert(int ,int ,DLList*);extern void Remove(int ,int ,DLList*);voidSimpleThread(int which) int num; for (num = 0; num Yield(); voidDLListThread(int t)Insert(t,n,dllist);Remove(t,n,dllist);void BufferThread(int t)char str10;char *p=str;char *q=str;if(t%2)=0)buffer-Write(p,10,t);elsebuffer-Read(q,10,t);printf(n);void TableThread(int t)int *p510; int i
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 單位管理制度分享大全人事管理篇十篇
- 單位管理制度呈現(xiàn)大合集人事管理十篇
- 《行政職業(yè)能力測驗》山西省呂梁地區(qū)嵐縣2024年公務(wù)員考試全真模擬試卷含解析
- 《喜迎中秋模板》課件
- 新餐飲浪潮的魅力
- 重癥監(jiān)護(hù)室護(hù)士工作總結(jié)
- 婦科護(hù)士的工作心得
- 2023年-2024年項目部安全管理人員安全培訓(xùn)考試題及答案基礎(chǔ)題
- 2023-2024年項目管理人員安全培訓(xùn)考試題答案典型題匯編
- 2023年-2024年新員工入職安全教育培訓(xùn)試題含答案【突破訓(xùn)練】
- 食品安全應(yīng)急管理和突發(fā)事故報告制度
- 藝術(shù)學(xué)概論第一章-彭吉象
- 51job在線測評題集
- 2024新教科版一年級科學(xué)上冊全冊教案
- 2024兒童身高現(xiàn)狀報告
- 趣味知識問答100道
- 紫砂壺介紹課件
- 2023年度學(xué)校食堂食品從業(yè)人員考核試題(附答案)
- 伊朗政府與政治課件
- 上交所金橋數(shù)據(jù)中心用戶手冊
- 互聯(lián)網(wǎng)金融(同濟大學(xué))智慧樹知到期末考試答案章節(jié)答案2024年同濟大學(xué)
評論
0/150
提交評論