下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、Synchronization: AdvancedIntroduction to Computer Systems28th Lecture, Dec. 26, 2013Instructors: Xiangqun Chen,Junlin LuGuangyu Sun,Xuetao GuanReview: SemaphoresSemaphore: non-negative global integer synchronization variableManipulated by P and V operations:P(s): while (s = 0) wait(); s-; Dutch for
2、Proberen (test)V(s): s+; Dutch for Verhogen (increment)OS kernel guarantees that operations between brackets are executed indivisiblyOnly one P or V operation at a time can modify s.When while loop in P terminates, only that P can decrement sSemaphore invariant: (s = 0)Review: Using semaphores to pr
3、otect shared resources via mutual exclusionBasic idea:Associate a unique semaphore mutex, initially 1, with each shared variable (or related set of shared variables)Surround each access to the shared variable(s) with P(mutex) and V(mutex) operations mutex = 1 P(mutex) cnt+ V(mutex)TodayUsing semapho
4、res to schedule shared resourcesProducer-consumer problemReaders-writers problemOther concurrency issuesThread safetyRacesDeadlocksUsing Semaphores to Coordinate Access to Shared ResourcesBasic idea: Thread uses a semaphore operation to notify another thread that some condition has e trueUse countin
5、g semaphores to keep track of resource state.Use binary semaphores to notify other threads. Two classic examples:The Producer-Consumer ProblemThe Readers-Writers ProblemProducer-Consumer ProblemCommon synchronization pattern:Producer waits for empty slot, inserts item in buffer, and notifies consume
6、rConsumer waits for item, removes it from buffer, and notifies producerExamplesMultimedia processing:Producer creates MPEG video frames, consumer renders them Event-driven graphical user interfacesProducer detects mouse clicks, mouse movements, and keyboard hits and inserts corresponding events in b
7、uffer Consumer retrieves events from buffer and paints the displayproducerthreadsharedbufferconsumerthreadProducer-Consumer on 1-element Buffer#include “csapp.h”#define NITERS 5void *producer(void *arg);void *consumer(void *arg);struct int buf; /* shared var */ sem_t full; /* sems */ sem_t empty; sh
8、ared;int main() pthread_t tid_producer; pthread_t tid_consumer; /* Initialize the semaphores */ Sem_init(&shared.empty, 0, 1); Sem_init(&shared.full, 0, 0); /* Create threads and wait */ Pthread_create(&tid_producer, NULL, producer, NULL); Pthread_create(&tid_consumer, NULL, consumer, NULL); Pthread
9、_join(tid_producer, NULL); Pthread_join(tid_consumer, NULL); exit(0);Producer-Consumer on 1-element Buffervoid *producer(void *arg) int i, item; for (i=0; iNITERS; i+) /* Produce item */ item = i; printf(produced %dn, item); /* Write item to buf */ P(&shared.empty); shared.buf = item; V(&shared.full
10、); return NULL;void *consumer(void *arg) int i, item; for (i=0; iNITERS; i+) /* Read item from buf */ P(&shared.full); item = shared.buf; V(&shared.empty); /* Consume item */ printf(consumed %dn“, item); return NULL;Initially: empty=1, full=0Producer ThreadConsumer ThreadCounting with SemaphoresReme
11、mber, its a non-negative integerSo, values greater than 1 are legal Lets repeat thing_5() 5 times for every 3 of thing_3()/* thing_5 and thing_3 */#include “csapp.h”sem_t five;sem_t three;void *five_times(void *arg);void *three_times(void *arg);int main() pthread_t tid_five, tid_three; /* initialize
12、 the semaphores */ Sem_init(&five, 0, 5); Sem_init(&three, 0, 3); /* create threads and wait */ Pthread_create(&tid_five, NULL, five_times, NULL); Pthread_create(&tid_three, NULL, three_times, NULL); . . .Counting with semaphores (cont)/* thing_5() thread */void *five_times(void *arg) int i; while (
13、1) for (i=0; i5; i+) /* wait & thing_5() */ P(&five); thing_5(); V(&three); V(&three); V(&three); return NULL;/* thing_3() thread */void *three_times(void *arg) int i; while (1) for (i=0; ibuf = Calloc(n, sizeof(int); sp-n = n; /* Buffer holds max of n items */ sp-front = sp-rear = 0; /* Empty buffe
14、r iff front = rear */ Sem_init(&sp-mutex, 0, 1); /* Binary semaphore for locking */ Sem_init(&sp-slots, 0, n); /* Initially, buf has n empty slots */ Sem_init(&sp-items, 0, 0); /* Initially, buf has zero items */* Clean up buffer sp */void sbuf_deinit(sbuf_t *sp) Free(sp-buf);sbuf.cInitializing and
15、deinitializing a shared buffer:sbuf Package - Implementation/* Insert item onto the rear of shared buffer sp */void sbuf_insert(sbuf_t *sp, int item) P(&sp-slots); /* Wait for available slot */ P(&sp-mutex); /* Lock the buffer */ sp-buf(+sp-rear)%(sp-n) = item; /* Insert the item */ V(&sp-mutex); /*
16、 Unlock the buffer */ V(&sp-items); /* Announce available item */sbuf.cInserting an item into a shared buffer:sbuf Package - Implementation/* Remove and return the first item from buffer sp */int sbuf_remove(sbuf_t *sp) int item; P(&sp-items); /* Wait for available item */ P(&sp-mutex); /* Lock the
17、buffer */ item = sp-buf(+sp-front)%(sp-n); /* Remove the item */ V(&sp-mutex); /* Unlock the buffer */ V(&sp-slots); /* Announce available slot */ return item;sbuf.cRemoving an item from a shared buffer:Readers-Writers ProblemGeneralization of the mutual exclusion problemProblem statement:Reader thr
18、eads only read the objectWriter threads modify the objectWriters must have exclusive access to the objectUnlimited number of readers can access the objectOccurs frequently in real systems, e.g.,Online airline reservation systemMultithreaded caching Web proxyVariants of Readers-WritersFirst readers-w
19、riters problem (favors readers)No reader should be kept waiting unless a writer has already been granted permission to use the object. A reader that arrives after a waiting writer gets priority over the writer. Second readers-writers problem (favors writers)Once a writer is ready to write, it perfor
20、ms its write as soon as possible A reader that arrives after a writer must wait, even if the writer is also waiting. Starvation (where a thread waits indefinitely) is possible in both cases. Solution to First Readers-Writers Problemint readcnt; /* Initially 0 */sem_t mutex, w; /* Both initially 1 */
21、void reader(void) while (1) P(&mutex); readcnt+; if (readcnt = 1) /* First in */ P(&w); V(&mutex); /* Reading happens here */ P(&mutex); readcnt-; if (readcnt = 0) /* Last out */ V(&w); V(&mutex); void writer(void) while (1) P(&w); /* Writing here */ V(&w); Readers:Writers:rw1.cTodayUsing semaphores
22、 to schedule shared resourcesProducer-consumer problemReaders-writers problemOther concurrency issuesThread safetyRacesDeadlocksCrucial concept: Thread SafetyFunctions called from a thread must be thread-safeDef: A function is thread-safe iff it will always produce correct results when called repeat
23、edly from multiple concurrent threads. Classes of thread-unsafe functions:Class 1: Functions that do not protect shared variablesClass 2: Functions that keep state across multiple invocationsClass 3: Functions that return a pointer to a static variableClass 4: Functions that call thread-unsafe funct
24、ionsThread-Unsafe Functions (Class 1)Failing to protect shared variablesFix: Use P and V semaphore operationsExample: goodcnt.cIssue: Synchronization operations will slow down codeThread-Unsafe Functions (Class 2)Relying on persistent state across multiple function invocationsExample: Random number
25、generator that relies on static state static unsigned int next = 1; /* rand: return pseudo-random integer on 0.32767 */ int rand(void) next = next*1103515245 + 12345; return (unsigned int)(next/65536) % 32768; /* srand: set seed for rand() */ void srand(unsigned int seed) next = seed; Thread-Safe Ra
26、ndom Number GeneratorPass state as part of argumentand, thereby, eliminate static state Consequence: programmer using rand_r must maintain seed/* rand_r - return pseudo-random integer on 0.32767 */ int rand_r(int *nextp) *nextp = *nextp*1103515245 + 12345; return (unsigned int)(*nextp/65536) % 32768
27、; Thread-Unsafe Functions (Class 3)Returning a pointer to a static variableFix 1. Rewrite function so caller passes address of variable to store resultRequires changes in caller and calleeFix 2. Lock-and-copyRequires simple changes in caller (and none in callee)However, caller must free memory. /* l
28、ock-and-copy version */char *ctime_ts(const time_t *timep, char *privatep) char *sharedp; P(&mutex); sharedp = ctime(timep); strcpy(privatep, sharedp); V(&mutex); return privatep;Warning: Some functions like gethostbyname require a deep copy. Use reentrant gethostbyname_r version instead.Thread-Unsa
29、fe Functions (Class 4)Calling thread-unsafe functionsCalling one thread-unsafe function makes the entire function that calls it thread-unsafeFix: Modify the function so it calls only thread-safe functions Reentrant FunctionsDef: A function is reentrant iff it accesses no shared variables when called
30、 by multiple threads. Important subset of thread-safe functionsRequire no synchronization operationsOnly way to make a Class 2 function thread-safe is to make it reetnrant (e.g., rand_r )ReentrantfunctionsAll functionsThread-unsafefunctionsThread-safefunctionsThread-Safe Library FunctionsAll functio
31、ns in the Standard C Library (at the back of your K&R text) are thread-safeExamples: malloc, free, printf, scanfMost Unix system calls are thread-safe, with a few exceptions:Thread-unsafe functionClassReentrant versionasctime 3asctime_rctime 3ctime_rgethostbyaddr 3gethostbyaddr_rgethostbyname 3getho
32、stbyname_rinet_ntoa 3(none)localtime 3localtime_rrand 2rand_rThreads SummaryThreads provide another mechanism for writing concurrent programsThreads are growing in popularitySomewhat cheaper than processesEasy to share data between threadsHowever, the ease of sharing has a cost:Easy to introduce sub
33、tle synchronization errorsTread carefully with threads!For more info:D. Butenhof, “Programming with Posix Threads”, Addison-Wesley, 1997Case Study: Prethreaded Concurrent ServerMasterthread Buffer.AcceptconnectionsInsertdescriptorsRemovedescriptorsWorkerthreadWorkerthread ClientClient.Service client
34、Service clientPool of worker threadsPrethreaded Concurrent Serversbuf_t sbuf; /* Shared buffer of connected descriptors */int main(int argc, char *argv) int i, listenfd, connfd, port; socklen_t clientlen=sizeof(struct sockaddr_in); struct sockaddr_in clientaddr; pthread_t tid; port = atoi(argv1); sb
35、uf_init(&sbuf, SBUFSIZE); listenfd = Open_listenfd(port); for (i = 0; i NTHREADS; i+) /* Create worker threads */ Pthread_create(&tid, NULL, thread, NULL); while (1) connfd = Accept(listenfd, (SA *) &clientaddr, &clientlen); sbuf_insert(&sbuf, connfd); /* Insert connfd in buffer */ echoservert_pre.c
36、Prethreaded Concurrent Servervoid *thread(void *vargp) Pthread_detach(pthread_self(); while (1) int connfd = sbuf_remove(&sbuf); /* Remove connfd from buffer */ echo_cnt(connfd); /* Service client */ Close(connfd); echoservert_pre.cWorker thread routine: Prethreaded Concurrent Serverstatic int byte_
37、cnt; /* Byte counter */static sem_t mutex; /* and the mutex that protects it */static void init_echo_cnt(void) Sem_init(&mutex, 0, 1); byte_cnt = 0;echo_cnt.cecho_cnt initialization routine:Prethreaded Concurrent Servervoid echo_cnt(int connfd) int n; char bufMAXLINE; rio_t rio; static pthread_once_
38、t once = PTHREAD_ONCE_INIT; Pthread_once(&once, init_echo_cnt); Rio_readinitb(&rio, connfd); while(n = Rio_readlineb(&rio, buf, MAXLINE) != 0) P(&mutex); byte_cnt += n; printf(thread %d received %d (%d total) bytes on fd %dn”, (int) pthread_self(), n, byte_cnt, connfd); V(&mutex); Rio_writen(connfd,
39、 buf, n); Worker thread service routine:echo_cnt.cOne worry: RacesA race occurs when correctness of the program depends on one thread reaching point x before another thread reaches point y/* a threaded program with a race */int main() pthread_t tidN; int i; for (i = 0; i N; i+) Pthread_create(&tidi,
40、 NULL, thread, &i); for (i = 0; i N; i+) Pthread_join(tidi, NULL); exit(0);/* thread routine */void *thread(void *vargp) int myid = *(int *)vargp); printf(Hello from thread %dn, myid); return NULL;race.cRace EliminationMake sure dont have unintended sharing of state/* a threaded program without the
41、race */int main() pthread_t tidN; int i; for (i = 0; i N; i+) int *valp = malloc(sizeof(int); *valp = i; Pthread_create(&tidi, NULL, thread, valp); for (i = 0; i N; i+) Pthread_join(tidi, NULL); exit(0);/* thread routine */void *thread(void *vargp) int myid = *(int *)vargp); free(vargp); printf(Hell
42、o from thread %dn, myid); return NULL;norace.cAnother worry: DeadlockDef: A process is deadlocked iff it is waiting for a condition that will never be true. Typical ScenarioProcesses 1 and 2 needs two resources (A and B) to proceedProcess 1 acquires A, waits for BProcess 2 acquires B, waits for ABot
43、h will wait forever!Deadlocking With Semaphoresint main() pthread_t tid2; Sem_init(&mutex0, 0, 1); /* mutex0 = 1 */ Sem_init(&mutex1, 0, 1); /* mutex1 = 1 */ Pthread_create(&tid0, NULL, count, (void*) 0); Pthread_create(&tid1, NULL, count, (void*) 1); Pthread_join(tid0, NULL); Pthread_join(tid1, NULL); printf(cnt=%dn, cnt); exit(0);void *count(void *vargp) int i; int id = (int) vargp; for (i = 0; i NITERS; i+) P(&mutexi
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 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ì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 中國(guó)音樂(lè)學(xué)院《生物學(xué)課程與教材研究》2023-2024學(xué)年第一學(xué)期期末試卷
- 長(zhǎng)春職業(yè)技術(shù)學(xué)院《模擬法庭競(jìng)賽》2023-2024學(xué)年第一學(xué)期期末試卷
- 豫章師范學(xué)院《汽車(chē)用品設(shè)計(jì)》2023-2024學(xué)年第一學(xué)期期末試卷
- 霧霾天氣下空氣質(zhì)量改善措施
- 財(cái)務(wù)總結(jié)報(bào)告及行動(dòng)計(jì)劃模板
- Q2業(yè)務(wù)運(yùn)營(yíng)報(bào)告模板
- 業(yè)務(wù)操作-房地產(chǎn)經(jīng)紀(jì)人《業(yè)務(wù)操作》名師預(yù)測(cè)卷2
- 二零二五版加固工程加固施工與信息化合同3篇
- 二零二五年度航空航天發(fā)明專(zhuān)利權(quán)入股技術(shù)轉(zhuǎn)化協(xié)議3篇
- 二零二五版出租車(chē)駕駛員勞動(dòng)合同執(zhí)行規(guī)范5篇
- 學(xué)校對(duì)口幫扶工作計(jì)劃
- 2024年醫(yī)師定期考核臨床業(yè)務(wù)知識(shí)考試題庫(kù)及答案(共三套)
- 建筑材料供應(yīng)鏈管理服務(wù)合同
- 孩子改名字父母一方委托書(shū)
- 2024-2025學(xué)年人教版初中物理九年級(jí)全一冊(cè)《電與磁》單元測(cè)試卷(原卷版)
- 江蘇單招英語(yǔ)考綱詞匯
- 2024年事業(yè)單位財(cái)務(wù)工作計(jì)劃例文(6篇)
- 2024年工程咨詢服務(wù)承諾書(shū)
- 青桔單車(chē)保險(xiǎn)合同條例
- 車(chē)輛使用不過(guò)戶免責(zé)協(xié)議書(shū)范文范本
- 2023-2024學(xué)年天津市部分區(qū)九年級(jí)(上)期末物理試卷
評(píng)論
0/150
提交評(píng)論