主頁(yè) > 知識(shí)庫(kù) > linux線程間的同步與互斥知識(shí)點(diǎn)總結(jié)

linux線程間的同步與互斥知識(shí)點(diǎn)總結(jié)

熱門標(biāo)簽:外呼系統(tǒng)打哪顯哪 新科美甲店地圖標(biāo)注 高德地圖標(biāo)注論壇 北海市地圖標(biāo)注app 湖北ai智能電銷機(jī)器人 AI電銷機(jī)器人 源碼 江西外呼系統(tǒng) 新邵電銷機(jī)器人企業(yè) 蘭州ai電銷機(jī)器人招商

在線程并發(fā)執(zhí)行的時(shí)候,我們需要保證臨界資源的安全訪問(wèn),防止線程爭(zhēng)搶資源,造成數(shù)據(jù)二義性。

線程同步: 條件變量

為什么使用條件變量?

對(duì)臨界資源的時(shí)序可控性,條件滿足會(huì)通知其他等待操作臨界資源的線程,類似信號(hào)。 場(chǎng)景:T-DAY展會(huì)排隊(duì)參觀/生產(chǎn)者消費(fèi)者模型

條件變量是什么?

是一種同步機(jī)制,一個(gè)線程用于修改這個(gè)變量使其滿足其它線程繼續(xù)往下執(zhí)行的條件,其它線程則接收條件已經(jīng)發(fā)生改變的信號(hào)。

條件變量操作?

初始化和銷毀

pthread_cond_wait

條件不滿足 會(huì)釋放鎖并阻塞等待 , 這個(gè)函數(shù)是原子性操作:1.將線程放入條件等待隊(duì)列 2.釋放鎖 

條件滿足 則線程會(huì)被喚醒并加鎖

pthread_cond_signal 一對(duì)一喚醒   

喚醒等待隊(duì)列中的一個(gè)線程

pthread_cond_broadcast 廣播喚醒

喚醒等待隊(duì)列中的全部線程 

為什么等待和解鎖需要原子操作/為什么條件變量要使用互斥鎖?

因?yàn)閜thread_cond_wait中的鎖是為了保護(hù)條件變量,防止錯(cuò)過(guò)信號(hào),如果等待解鎖不是原子性操作,比如線程A先解鎖,此時(shí)CPU時(shí)間片切換到線程B,線程B加鎖并發(fā)送條件變量信號(hào),此時(shí)再切換到線程A,線程A還來(lái)不及等待就錯(cuò)過(guò)了信號(hào),就可能會(huì)永久阻塞下去。所以,等待和解鎖必須是原子性操作。

為什么需要while循環(huán)判斷臨界資源是否存在?

在一對(duì)多的情況下,生產(chǎn)者發(fā)送一個(gè)信號(hào),等待的線程被喚醒并加鎖,但是只有一個(gè)線程能加鎖,其他線程就會(huì)阻塞等待鎖,如果這個(gè)線程用完了臨界資源,其他線程不進(jìn)行判斷就繼續(xù)往下走,是不合理的。

singnal要先解鎖還是后解鎖?

如果先解鎖,鎖被沒(méi)有阻塞等待的線程拿到了,再把臨界資源使用了,解鎖后的singal就沒(méi)意義了,也就是虛假喚醒;

先singal喚醒,再讓喚醒的線程爭(zhēng)搶鎖,在linux下,有兩個(gè)隊(duì)列,一個(gè)是cond_wait,一個(gè)是mutex_lock,singal只是讓cond_wait上的線程轉(zhuǎn)移到mutex_lock,不會(huì)返回用戶空間,這樣能提高效率。

線程互斥: 互斥鎖

為什么使用互斥鎖?

對(duì)臨界資源同時(shí)間唯一訪問(wèn),保護(hù)臨界資源防止修改。 場(chǎng)景:黃牛搶票

互斥鎖是什么?

是一個(gè)0/1計(jì)數(shù)器,1代表有資源能操作,0代表沒(méi)有資源可以操作。

互斥鎖操作?

初始化和銷毀

加鎖---如果計(jì)數(shù)為1,置0,進(jìn)行需要的操作;如果計(jì)數(shù)為0,則阻塞等待計(jì)數(shù)變?yōu)?

解鎖---計(jì)數(shù)置為1

以上就是本次介紹的全部相關(guān)知識(shí)點(diǎn),感謝大家的學(xué)習(xí)和對(duì)腳本之家的支持。

標(biāo)簽:海南 南陽(yáng) 自貢 黔東 池州 大理 阿克蘇 黃石

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《linux線程間的同步與互斥知識(shí)點(diǎn)總結(jié)》,本文關(guān)鍵詞  linux,線程,間的,同步,與,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《linux線程間的同步與互斥知識(shí)點(diǎn)總結(jié)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于linux線程間的同步與互斥知識(shí)點(diǎn)總結(jié)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章