0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

兩個線程和互斥鎖如何形成死循環(huán)?

璟琰乀 ? 來源:一口Linux ? 作者:一口Linux ? 2021-01-02 16:47 ? 次閱讀

兩個線程,兩個互斥鎖如何形成死鎖?程序流程圖如下:

UF7nYf.png

程序流程圖

如上圖所示:

t0時刻,主線程創(chuàng)建子線程,并初始化互斥鎖mutex1、mutex2;

t1時刻,主線程申請到了mutex1、子線程申請到了mutex2;

t2時刻,主線程和子線程都sleep 1秒鐘,防止優(yōu)先獲得時間片的線程直接申請到了另外1個互斥鎖,導(dǎo)致程序直接退出;

t3時刻,主線程和子線程都想獲得對方手里的互斥鎖,但是對方都來不及釋放自己手里的鎖;

t4時刻,主線程和子線雙雙進(jìn)入休眠。

【注意】為了保證主線程和子線程都能夠分別獲得鎖mutex1、mutex2,各自獲得鎖后一定要先sleep 1秒鐘,否則創(chuàng)建完子線程后,主線程還有一定的時間片,主線程會申請到鎖mutex2,無法形成死鎖。

死鎖

源碼如下#include 《stdio.h》#include 《stdlib.h》#include 《string.h》#include 《pthread.h》 unsigned int value1, value2, count;pthread_mutex_t mutex1,mutex2;void *function(void *arg);void *function(void *arg){ pthread_mutex_lock(&mutex2); printf(“new thread get mutex2 ”); sleep(1); pthread_mutex_lock(&mutex1); printf(“new thread get mutex1 ”); pthread_mutex_unlock(&mutex1); printf(“new thread release mutex1 ”); pthread_mutex_unlock(&mutex2); printf(“new thread release mutex2 ”); return NULL; } int main(int argc, char *argv[]){ pthread_t a_thread; if (pthread_mutex_init(&mutex1, NULL) 《 0) { perror(“fail to mutex_init”); exit(-1); } if (pthread_mutex_init(&mutex2, NULL) 《 0) { perror(“fail to mutex_init”); exit(-1); } if (pthread_create(&a_thread, NULL, function, NULL) 《 0) { perror(“fail to pthread_create”); exit(-1); } while ( 1 ) { pthread_mutex_lock(&mutex1); printf(“main thread get mutex1 ”); sleep(1); pthread_mutex_lock(&mutex2); printf(“main thread get mutex2 ”); pthread_mutex_unlock(&mutex2); printf(“main thread release mutex2 ”); pthread_mutex_unlock(&mutex1); printf(“main thread release mutex1 ”); } return 0; }

編譯運(yùn)行

Q7reqy.png

從執(zhí)行結(jié)果可以判斷,主線程和子線程分別獲得了互斥鎖mutex1、mutex2,sleep 1秒后,他們都想再分別申請mutex2、mutex1,而雙方都不想釋放自己手中的鎖,鎖已形成了死鎖,程序就一直處于休眠狀態(tài)。

查看下該進(jìn)程的線程查看進(jìn)程ID,為4204

qaYFb2.png

查看該進(jìn)程創(chuàng)建的線程id:4204、4205。

MZJJb2.png

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 編程
    +關(guān)注

    關(guān)注

    88

    文章

    3634

    瀏覽量

    93880
  • 線程
    +關(guān)注

    關(guān)注

    0

    文章

    505

    瀏覽量

    19716
收藏 人收藏

    評論

    相關(guān)推薦

    sr存器特性表q為什么有兩個

    SR存器特性表中Q之所以有兩個值,是因?yàn)檫@些值分別代表了存器在不同輸入條件下的狀態(tài)。具體來說,Q的兩個值分別對應(yīng)了存器的“當(dāng)前狀態(tài)”(
    的頭像 發(fā)表于 08-28 09:28 ?834次閱讀

    互斥和自旋的實(shí)現(xiàn)原理

    互斥和自旋是操作系統(tǒng)中常用的同步機(jī)制,用于控制對共享資源的訪問,以避免多個線程或進(jìn)程同時訪問同一資源,從而引發(fā)數(shù)據(jù)不一致或競爭條件等問題。 互斥
    的頭像 發(fā)表于 07-10 10:07 ?563次閱讀

    自旋互斥的使用場景是什么

    自旋互斥種常見的同步機(jī)制,它們在多線程編程中被廣泛使用。在本文中,我們將介紹自旋
    的頭像 發(fā)表于 07-10 10:05 ?1073次閱讀

    兩個銅片可以形成原電池嗎

    兩個銅片本身不能形成原電池,因?yàn)樵姵氐墓ぷ髟硪蕾囉?b class='flag-5'>兩個不同電位的電極材料之間的氧化還原反應(yīng)。
    的頭像 發(fā)表于 05-21 16:23 ?1082次閱讀

    STM32F3執(zhí)行函數(shù)的時候進(jìn)入HardFault_Handler死循環(huán),怎么處理?

    + (uint32_t)(dataRx1 << 16)); return *Result; } 執(zhí)行這個函數(shù)的時候進(jìn)入HardFault_Handler死循環(huán),求助怎么處理?函數(shù)功能是從某個芯片中讀取兩個字,網(wǎng)上都說是接收緩沖區(qū)小了,請問各位怎么處理???
    發(fā)表于 05-13 07:35

    創(chuàng)建了兩個task如果一優(yōu)先級高 一優(yōu)先級低,高優(yōu)先級的那個一直在做,什么時候會調(diào)度到低優(yōu)先級的呢?

    創(chuàng)建了兩個task如果一優(yōu)先級高一優(yōu)先級低, 我看到任務(wù)的函數(shù)都是用死循環(huán)做的,那個高優(yōu)先級的那個一直在做,什么時候會調(diào)度到低優(yōu)先級的呢?
    發(fā)表于 05-13 07:13

    STM32F107中斷死循環(huán)的原因?

    STM32F107,中斷死循環(huán)
    發(fā)表于 05-11 06:31

    在freertos中,每個任務(wù)都是一死循環(huán),那么還需要使用看門狗嗎?

    在freertos中,每個任務(wù)都是一死循環(huán),那么還需要使用看門狗嗎?該怎么使用?
    發(fā)表于 05-07 06:55

    聊聊MCU死循環(huán),用for(;;)還是while(1)?

    首先,問大家一問題:你們寫單片機(jī)程序【死循環(huán)】時,喜歡用for(;;)還是while(1)?快來為你喜歡用的【死循環(huán)】打call,評論區(qū)等你哦~一位工程師發(fā)現(xiàn),國外工程師在給demo在做死循
    的頭像 發(fā)表于 04-29 08:10 ?1431次閱讀
    聊聊MCU<b class='flag-5'>死循環(huán)</b>,用for(;;)還是while(1)?

    關(guān)于FreeRTOS互斥量的用法求解

    會引起死,比如當(dāng)同一任務(wù)多次搶占時, 最后還是得換到互斥量, 基于串口中斷發(fā)送模式, 希望使用互斥量來訪問串口的話 , 該如何釋放發(fā)送完成信號呢? 在中斷函數(shù)中釋放
    發(fā)表于 04-24 08:03

    如何讓同一條件結(jié)構(gòu)里的兩個循環(huán)同時獨(dú)立運(yùn)行

    由于兩個循環(huán)里都用了定時功能,導(dǎo)致兩個循環(huán)都被那個設(shè)置時間長的定時影響了
    發(fā)表于 04-08 11:35

    為何國外工程師偏愛使用for(;;)來實(shí)現(xiàn)MCU死循環(huán)

    一位工程師發(fā)現(xiàn),國外工程師在給demo在做死循環(huán)時用的是for(;;),而不是常用的while(1)。這僅僅是個人習(xí)慣的問題,還是有更深層次的含義?
    發(fā)表于 04-01 11:26 ?696次閱讀
    為何國外工程師偏愛使用for(;;)來實(shí)現(xiàn)MCU<b class='flag-5'>死循環(huán)</b>?

    請問rtt線程內(nèi)必須顯式調(diào)用調(diào)度函數(shù)嗎?

    我在一線程中 當(dāng)創(chuàng)建對象失敗的時候,會使用while(1)printf(“create obj failed!!\\n”) 方式進(jìn)入死循環(huán),這時候其他線程就不在運(yùn)行了(表現(xiàn)是LCD上
    發(fā)表于 02-26 06:36

    arcgis中如何關(guān)聯(lián)兩個屬性表

    在ArcGIS中,關(guān)聯(lián)兩個屬性表是一重要的操作,可以通過此操作將兩個表中的數(shù)據(jù)關(guān)聯(lián)起來,以便進(jìn)行分析和查詢。下面是詳細(xì)介紹如何在ArcGIS中實(shí)現(xiàn)屬性表的關(guān)聯(lián)。 首先,我們需要明確兩個
    的頭像 發(fā)表于 02-25 11:01 ?4390次閱讀

    RTThread中main線程循環(huán),如果main線程異常退出了,有什么辦法可以監(jiān)測到?

    RTThread中main線程循環(huán),如果main線程異常退出了,有什么辦法可以監(jiān)測到?
    發(fā)表于 02-22 08:15