線程同步之條件變量

在多線程編程中驰坊,線程的同步是一個宏觀的概念荡陷,其實其內(nèi)部的實現(xiàn)包含兩個部分:一是互斥励两,二是線程之間的相互依賴關系噩茄。
就好像是一個團隊開發(fā)一個軟件項目,加入有兩個小組续徽,分別是:研發(fā)小組和測試小組蚓曼。按照我們的經(jīng)驗,一個軟件項目钦扭,只有當研發(fā)小組將其開發(fā)出來以后纫版,測試小組才可以對其進行測試,這說明測試小組是依賴于研發(fā)小組的客情。如果我們把該軟件項目看成是一個共享資源其弊,這個情景就可以看作是一個線程的同步問題。


image.png

為了實現(xiàn)線程的同步膀斋,我們引入條件變量瑞凑。條件變量的內(nèi)部是一個等待隊列,用于放置等待的線程概页,線程在條件變量中等待通知籽御。


image.png

對于等待變量的操作,也是對一個共享資源的操作惰匙,所以也需要互斥鎖對其進行保護技掏。所以在線程同步的問題中,互斥鎖和等待變量常常是一起使用的项鬼。

我們使用pthread_cond_wait(pthread_cond_t * cond,pthread_mutex_t * mutex)這一函數(shù)來實現(xiàn)等待變量的等待操作哑梳。
這里就要好好說一下pthread_cond_wait(pthread_cond_t * cond,pthread_mutex_t * mutex)這一函數(shù)的內(nèi)部實現(xiàn)原理:
偽代碼說明:

pthread_cond_wait(pthread_cond_t * cond,pthread_mutex_t * mutex)
{
1、unlock(mutex);//這里首先要將互斥鎖打開绘盟,
2鸠真、lock(mutex);//然后使用互斥鎖上鎖
3、將線程自己插入到條件變量的等待隊列當中
4龄毡、unlock(&mutex);
5吠卷、當前等待的線程阻塞<--------等待其他線程通知喚醒
6、該線程被喚醒以后沦零,lock(&mutex);
7祭隔、將自己從等待隊列中刪除
}

這就能解釋為什么在下圖中,pthread_cond_wait(&r-> cond,&r->mutex)放在pthread_mutex_unlock(&r->mutex)之前路操。


image.png
最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末疾渴,一起剝皮案震驚了整個濱河市千贯,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌搞坝,老刑警劉巖搔谴,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異桩撮,居然都是意外死亡己沛,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門距境,熙熙樓的掌柜王于貴愁眉苦臉地迎上來申尼,“玉大人,你說我怎么就攤上這事垫桂∈δ唬” “怎么了?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵诬滩,是天一觀的道長霹粥。 經(jīng)常有香客問我,道長疼鸟,這世上最難降的妖魔是什么后控? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮空镜,結果婚禮上浩淘,老公的妹妹穿的比我還像新娘。我一直安慰自己吴攒,他們只是感情好张抄,可當我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著洼怔,像睡著了一般署惯。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上镣隶,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天极谊,我揣著相機與錄音,去河邊找鬼安岂。 笑死轻猖,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的嗜闻。 我是一名探鬼主播蜕依,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼桅锄,長吁一口氣:“原來是場噩夢啊……” “哼琉雳!你這毒婦竟也來了样眠?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤翠肘,失蹤者是張志新(化名)和其女友劉穎檐束,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體束倍,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡被丧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了绪妹。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片甥桂。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖邮旷,靈堂內(nèi)的尸體忽然破棺而出黄选,到底是詐尸還是另有隱情,我是刑警寧澤婶肩,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布办陷,位于F島的核電站,受9級特大地震影響律歼,放射性物質發(fā)生泄漏民镜。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一险毁、第九天 我趴在偏房一處隱蔽的房頂上張望制圈。 院中可真熱鬧,春花似錦畔况、人聲如沸离唐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽亥鬓。三九已至,卻和暖如春域庇,著一層夾襖步出監(jiān)牢的瞬間嵌戈,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工听皿, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留熟呛,地道東北人。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓尉姨,卻偏偏與公主長得像庵朝,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,828評論 2 345

推薦閱讀更多精彩內(nèi)容

  • linux線程同步 信號燈:與互斥鎖和條件變量的主要不同在于"燈"的概念九府,燈亮則意味著資源可用椎瘟,燈滅則意味著不可用...
    鮑陳飛閱讀 682評論 0 2
  • 轉自:Youtherhttps://www.cnblogs.com/youtherhome/archive/201...
    njukay閱讀 1,606評論 0 52
  • 引用自多線程編程指南應用程序里面多個線程的存在引發(fā)了多個執(zhí)行線程安全訪問資源的潛在問題。兩個線程同時修改同一資源有...
    Mitchell閱讀 1,976評論 1 7
  • 線程基礎 線程是進程的一個執(zhí)行單元侄旬,執(zhí)行一段程序片段肺蔚,線程共享全局變量;線程的查看可以使用命令或者文件來進行查看儡羔;...
    秋風弄影閱讀 734評論 0 0
  • 概念 線程同步的方法有多種宣羊,互斥量、信號量汰蜘、條件變量仇冯、讀寫鎖等∽宀伲互斥量在允許或阻塞對臨界區(qū)的訪問上是很有效的赞枕,線程...
    藍雪冬荷閱讀 1,070評論 0 3