linux線程間的同步與互斥知識點總結
在線程并發(fā)執(zhí)行的時候,我們需要保證臨界資源的安全訪問,防止線程爭搶資源,造成數(shù)據(jù)二義性。
線程同步: 條件變量
為什么使用條件變量?
對臨界資源的時序可控性,條件滿足會通知其他等待操作臨界資源的線程,類似信號。 場景:T-DAY展會排隊參觀/生產(chǎn)者消費者模型
條件變量是什么?
是一種同步機制,一個線程用于修改這個變量使其滿足其它線程繼續(xù)往下執(zhí)行的條件,其它線程則接收條件已經(jīng)發(fā)生改變的信號。
條件變量操作?
初始化和銷毀
pthread_cond_wait
條件不滿足 會釋放鎖并阻塞等待 , 這個函數(shù)是原子性操作:1.將線程放入條件等待隊列 2.釋放鎖
條件滿足 則線程會被喚醒并加鎖
pthread_cond_signal 一對一喚醒
喚醒等待隊列中的一個線程
pthread_cond_broadcast 廣播喚醒
喚醒等待隊列中的全部線程
為什么等待和解鎖需要原子操作/為什么條件變量要使用互斥鎖?
因為pthread_cond_wait中的鎖是為了保護條件變量,防止錯過信號,如果等待解鎖不是原子性操作,比如線程A先解鎖,此時CPU時間片切換到線程B,線程B加鎖并發(fā)送條件變量信號,此時再切換到線程A,線程A還來不及等待就錯過了信號,就可能會永久阻塞下去。所以,等待和解鎖必須是原子性操作。
為什么需要while循環(huán)判斷臨界資源是否存在?
在一對多的情況下,生產(chǎn)者發(fā)送一個信號,等待的線程被喚醒并加鎖,但是只有一個線程能加鎖,其他線程就會阻塞等待鎖,如果這個線程用完了臨界資源,其他線程不進行判斷就繼續(xù)往下走,是不合理的。
singnal要先解鎖還是后解鎖?
如果先解鎖,鎖被沒有阻塞等待的線程拿到了,再把臨界資源使用了,解鎖后的singal就沒意義了,也就是虛假喚醒;
先singal喚醒,再讓喚醒的線程爭搶鎖,在linux下,有兩個隊列,一個是cond_wait,一個是mutex_lock,singal只是讓cond_wait上的線程轉移到mutex_lock,不會返回用戶空間,這樣能提高效率。
線程互斥: 互斥鎖
為什么使用互斥鎖?
對臨界資源同時間唯一訪問,保護臨界資源防止修改。 場景:黃牛搶票
互斥鎖是什么?
是一個0/1計數(shù)器,1代表有資源能操作,0代表沒有資源可以操作。
互斥鎖操作?
初始化和銷毀
加鎖---如果計數(shù)為1,置0,進行需要的操作;如果計數(shù)為0,則阻塞等待計數(shù)變?yōu)?
解鎖---計數(shù)置為1
以上就是本次介紹的全部相關知識點,感謝大家的學習和對我們的支持。
上一篇:詳解firewall的規(guī)則設置與命令(白名單設置)
欄 目:Linux/apache
下一篇:Ubuntu 18.04安裝 pyenv、pyenv-virtualenv、virtualenv、Numpy、SciPy
本文標題:linux線程間的同步與互斥知識點總結
本文地址:http://mengdiqiu.com.cn/a1/Linux_apache/10676.html
您可能感興趣的文章
- 04-02linux關閉串口命令 關閉linux端口命令
- 04-02linux文件命令重命名 linux重命名文件名命令
- 04-02linux命令注入過濾 linux 代碼注入
- 04-02linux中jobs命令 shell jobs命令
- 04-02linux依次執(zhí)行命令 linux命令的執(zhí)行過程是怎樣的?新手必讀
- 04-02linux命令免輸入 linux配置免密登錄
- 04-02linux命令注銷vnc linux命令行注銷用戶
- 04-02軟交換linux命令 軟交換網(wǎng)絡主要協(xié)議有哪些
- 04-02linux命令歷史記錄 linux查看歷史記錄的操作命令
- 04-02linux命令頁面 linux命令頁面中文


閱讀排行
本欄相關
- 04-02linux關閉串口命令 關閉linux端口命令
- 04-02linux文件命令重命名 linux重命名文件名
- 04-02linux中jobs命令 shell jobs命令
- 04-02linux命令注入過濾 linux 代碼注入
- 04-02linux依次執(zhí)行命令 linux命令的執(zhí)行過程
- 04-02linux命令注銷vnc linux命令行注銷用戶
- 04-02linux命令免輸入 linux配置免密登錄
- 04-02軟交換linux命令 軟交換網(wǎng)絡主要協(xié)議
- 04-02linux命令歷史記錄 linux查看歷史記錄的
- 04-02linux命令頁面 linux命令頁面中文
隨機閱讀
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10delphi制作wav文件的方法
- 04-02jquery與jsp,用jquery
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10C#中split用法實例總結
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文