Linux線程同步之間存在多種機(jī)制,條件變量是一種類似操作系統(tǒng)里提到的生產(chǎn)者-消費(fèi)者算法的同步機(jī)制,允許線程以無競爭的方式等待特定條件的發(fā)生。
示例偽代碼:
void* Thread1(void){ while(線程運(yùn)行條件成立){ … pthread_mutex_lock(qlock); while(條件成立)pthread_cond_wait(qcond,qlock);或者pthread_cond_wait(qcond,qlock,timeout); reset條件變量… pthread_mutex_unlock(qlock); }}void* Thread2(void){ while(線程運(yùn)行條件成立){ … pthread_mutex_lock(qlock); set了條件變量…//可以發(fā)送處理信號 pthread_cond_signal(qcond); 或者 pthread_cond_broadcast(qcond); pthread_mutex_unlock(qlock); }}
條件變量需要配合互斥量一起使用,互斥量作為參數(shù)傳入wait函數(shù),函數(shù)把調(diào)用線程放到等待條件的線程列表上,然后對互斥量解鎖,這兩個(gè)是原子操作。當(dāng)線程等待到條件,從wait函數(shù)返回之前,會再次鎖住互斥量。
1.Lock
2.Unlock
3.等待
4.Lock
5.Unlock
第2,3,4步是wait的內(nèi)部操作
在wait被喚醒后,還需要在while中去檢查條件,這是為了防止“驚群效應(yīng)”,比如有兩個(gè)線程同時(shí)阻塞在wait,先后醒來,快的線程做完處理然后把條件reset了,并且對互斥量解鎖,此時(shí)慢的線程在wait里獲得了鎖(即第4步)返回,還再去做處理就會出問題。
以上就是小編為大家?guī)淼臏\談Linux條件變量的使用全部內(nèi)容了,希望大家多多支持VEVB武林網(wǎng)~
新聞熱點(diǎn)
疑難解答
圖片精選