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

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

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

兩個(gè)線程,兩個(gè)互斥鎖如何形成死鎖

strongerHuang ? 來(lái)源:strongerHuang ? 作者:一口Linux ? 2020-12-28 09:24 ? 次閱讀

兩個(gè)線程,兩個(gè)互斥鎖如何形成死鎖?

程序流程圖如下:

c1122ad4-46d6-11eb-8b86-12bb97331649.png

程序流程圖

如上圖所示:

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

t1時(shí)刻,主線程申請(qǐng)到了mutex1、子線程申請(qǐng)到了mutex2;

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

t3時(shí)刻,主線程和子線程都想獲得對(duì)方手里的互斥鎖,但是對(duì)方都來(lái)不及釋放自己手里的鎖;

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

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

死鎖

源碼如下

o4YBAF_pNF-AMP79AABcucKRsVw255.jpg

pIYBAF_pNGaAFWMGAACMZONs3TM009.jpg

pIYBAF_pNGyAUgCQAABZTHs3PoA856.jpg

編譯運(yùn)行

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

查看下該進(jìn)程的線程

查看進(jìn)程ID,為4204

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

責(zé)任編輯:xj

原文標(biāo)題:兩個(gè)線程,兩個(gè)互斥鎖,怎么形成一個(gè)死循環(huán)?

文章出處:【微信公眾號(hào):strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

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

    關(guān)注

    0

    文章

    25

    瀏覽量

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

    關(guān)注

    0

    文章

    502

    瀏覽量

    19614

原文標(biāo)題:兩個(gè)線程,兩個(gè)互斥鎖,怎么形成一個(gè)死循環(huán)?

文章出處:【微信號(hào):strongerHuang,微信公眾號(hào):strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    ad如何設(shè)置兩個(gè)元器件的距離

    在Altium Designer(簡(jiǎn)稱AD)中設(shè)置兩個(gè)元器件之間的距離,主要是通過(guò)設(shè)置元器件間的安全間距(Clearance)規(guī)則來(lái)實(shí)現(xiàn)的。這個(gè)規(guī)則定義了元器件之間、元器件與走線之間以及其他設(shè)計(jì)元素
    的頭像 發(fā)表于 09-02 15:31 ?2707次閱讀

    sr存器特性表q為什么有兩個(gè)

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

    觸發(fā)器的兩個(gè)穩(wěn)定狀態(tài)分別是什么

    觸發(fā)器作為數(shù)字電路中的基本邏輯單元,具有兩個(gè)穩(wěn)定狀態(tài),這兩個(gè)狀態(tài)通常用于表示二進(jìn)制數(shù)碼中的0和1。
    的頭像 發(fā)表于 08-12 11:01 ?312次閱讀

    雙穩(wěn)態(tài)電路的兩個(gè)穩(wěn)定狀態(tài)是什么

    雙穩(wěn)態(tài)電路是一種具有兩個(gè)穩(wěn)定狀態(tài)的電子電路,廣泛應(yīng)用于數(shù)字電路、通信系統(tǒng)、存儲(chǔ)器等領(lǐng)域。 雙穩(wěn)態(tài)電路的基本概念 雙穩(wěn)態(tài)電路是一種具有兩個(gè)穩(wěn)定狀態(tài)的電路,即在沒(méi)有外部輸入信號(hào)的情況下,電路可以保持在
    的頭像 發(fā)表于 08-11 15:00 ?613次閱讀

    雙穩(wěn)態(tài)觸發(fā)器的兩個(gè)基本性質(zhì)是什么

    雙穩(wěn)態(tài)觸發(fā)器(Bistable Trigger)是一種具有兩個(gè)穩(wěn)定狀態(tài)的邏輯電路,廣泛應(yīng)用于數(shù)字電路設(shè)計(jì)中。它具有兩個(gè)基本性質(zhì):記憶性和切換性。 一、雙穩(wěn)態(tài)觸發(fā)器的基本概念 1.1 雙穩(wěn)態(tài)觸發(fā)器
    的頭像 發(fā)表于 08-11 10:08 ?443次閱讀

    兩個(gè)銅片可以形成原電池嗎

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

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

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

    兩個(gè)電位器地控制一個(gè)變頻器,如何接線?

    兩個(gè)電位器地控制一個(gè)變頻器,如何接線? 接線方式如下: 1. 首先,明確需要使用的電器設(shè)備。在這個(gè)場(chǎng)景中,我們需要兩個(gè)電位器(即可變電阻器)和一個(gè)
    的頭像 發(fā)表于 02-05 10:13 ?4414次閱讀

    如何給C語(yǔ)言中的函數(shù)定義兩個(gè)不同的名字?

    最近有位哥問(wèn)我,如何給C語(yǔ)言中的函數(shù)定義兩個(gè)不同的名字?就是這兩個(gè)名字都是指向同一個(gè)函數(shù),同一個(gè)地址,而且兩個(gè)名字都可以當(dāng)做函數(shù)來(lái)用的那種。
    的頭像 發(fā)表于 12-19 16:21 ?641次閱讀

    電子設(shè)計(jì)中的兩個(gè)不同概念:pcb與pcb封裝

    電子設(shè)計(jì)中的兩個(gè)不同概念:pcb與pcb封裝
    的頭像 發(fā)表于 12-11 15:49 ?710次閱讀

    兩個(gè)硬盤2個(gè)系統(tǒng)開(kāi)機(jī)切換

    切換兩個(gè)硬盤上的系統(tǒng)是一種常見(jiàn)的行為,可以讓用戶在不同的操作系統(tǒng)之間進(jìn)行切換,以滿足不同的需求。在本文中,我們將詳細(xì)介紹如何配置和使用兩個(gè)硬盤上的系統(tǒng)進(jìn)行切換。本文將分為以下幾個(gè)部分進(jìn)行討論:硬件
    的頭像 發(fā)表于 11-28 15:08 ?6750次閱讀

    MMU包含兩個(gè)模塊是什么

    的物理地址也有部分:PFN和offset,PFN( Physical frame number)是物理頁(yè)框number,offset和上面虛擬地址的offset相同,是頁(yè)內(nèi)偏移。 2-MMU包含兩個(gè)
    的頭像 發(fā)表于 11-26 15:40 ?554次閱讀
    MMU包含<b class='flag-5'>兩個(gè)</b>模塊是什么

    死鎖的現(xiàn)象以及原理

    前言 本文將從0到1寫一個(gè)死鎖檢測(cè)組件。源碼:deadlock_success.c 組件如何放入自己的項(xiàng)目里?把代碼末兩個(gè)Debug部分刪除,在你的項(xiàng)目里添加下面句代碼即可使用
    的頭像 發(fā)表于 11-13 16:30 ?493次閱讀
    <b class='flag-5'>死鎖</b>的現(xiàn)象以及原理

    死鎖的現(xiàn)象及原理

    組件如何放入自己的項(xiàng)目里?把代碼末兩個(gè)Debug部分刪除,在你的項(xiàng)目里添加下面句代碼即可使用死鎖檢測(cè)組件。 init_hook (); start_check (); 1. 死鎖的現(xiàn)
    的頭像 發(fā)表于 11-10 16:32 ?403次閱讀
    <b class='flag-5'>死鎖</b>的現(xiàn)象及原理

    運(yùn)算放大器的兩個(gè)工作區(qū)域

    運(yùn)算放大器通常有兩個(gè)工作區(qū)域,分別是線性區(qū)和飽和區(qū)。
    的頭像 發(fā)表于 11-09 10:27 ?1470次閱讀