Linux之死鎖與解決方式
死鎖
死鎖:指在一組進(jìn)程中的各個(gè)進(jìn)程均占有不會(huì)釋放的資源,但因互相申請(qǐng)被其他進(jìn)程所站用不會(huì)釋放的資源而處于的一種永久等待狀態(tài)。
死鎖現(xiàn)象:
- 現(xiàn)象1,如果執(zhí)行流加鎖完畢后,不進(jìn)行解鎖則會(huì)造成死鎖(上篇所述);
- 現(xiàn)象2,線程A獲取了1鎖,線程B獲取了2鎖,同時(shí)線程A還想獲取2鎖,線程B還想獲取1鎖
現(xiàn)象2模擬:
兩個(gè)線程都處于阻塞狀態(tài)
死鎖的必要條件
只要產(chǎn)生死鎖,這四個(gè)條件一定會(huì)出現(xiàn)
- 互斥:一個(gè)執(zhí)行流獲取互斥鎖后,其它執(zhí)行流不能再獲取該鎖
- 不可剝奪:A執(zhí)行流拿著鎖,未使用完之前不能被強(qiáng)行剝奪
- 循環(huán)等待:多個(gè)執(zhí)行流拿著對(duì)方想要的鎖,并且各執(zhí)行流還去請(qǐng)求對(duì)方的鎖
- 請(qǐng)求與保持:執(zhí)行流本身使用著一把鎖并不釋放,還在請(qǐng)求別的鎖
解決方案
使線程的加鎖順序一致
破壞環(huán)路等待條件
使用非阻塞鎖,一旦線程發(fā)現(xiàn)請(qǐng)求的鎖被使用,就去釋放自己擁有的鎖
在加鎖前,將臨界資源一次性分配給線程A再加鎖
try鎖:pthread_mutex_try
- 申請(qǐng)鎖失敗,錯(cuò)誤碼會(huì)返回
- 非阻塞鎖,申請(qǐng)失敗會(huì)立即返回
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
在Linux中打開(kāi)、提取和創(chuàng)建rar文件的操作方法
RAR 是一種流行的文件壓縮格式,以其高效的壓縮算法和將大文件壓縮為較小檔案的能力而聞名,雖然 Linux 本身支持 ZIP 和 TAR 等常見(jiàn)檔案格式,但處理 RAR 文件需要額外的工具,在這篇博文中,我們將探討如何在 Linux 中打開(kāi)、提取和創(chuàng)建 RAR 文件,需要的朋友可以參考下2024-04-04Linux下gdb調(diào)試打印數(shù)組元素以及說(shuō)明
這篇文章主要介紹了Linux下gdb調(diào)試打印數(shù)組元素以及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09新版ubuntu20.04 使用root用戶(hù)登錄系統(tǒng)的詳細(xì)教程
這篇文章主要介紹了新版ubuntu20.04 使用root用戶(hù)登錄系統(tǒng)的詳細(xì)教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08詳解阿里云CentOS Linux服務(wù)器上用postfix搭建郵件服務(wù)器
本篇文章主要介紹了詳解阿里云CentOS Linux服務(wù)器上用postfix搭建郵件服務(wù)器,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2016-12-12