亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

蟲蟲首頁| 資源下載| 資源專輯| 精品軟件
登錄| 注冊

您現(xiàn)在的位置是:首頁 > 技術(shù)閱讀 >  兩個(gè)線程,兩個(gè)互斥鎖,怎么形成一個(gè)死循環(huán)?

兩個(gè)線程,兩個(gè)互斥鎖,怎么形成一個(gè)死循環(huán)?

時(shí)間:2024-02-08

粉絲的提問,必須安排。

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

程序流程圖如下:

程序流程圖

如上圖所示:

  1. t0時(shí)刻,主線程創(chuàng)建子線程,并初始化互斥鎖mutex1、mutex2;
  2. t1時(shí)刻,主線程申請到了mutex1、子線程申請到了mutex2;
  3. t2時(shí)刻,主線程和子線程都sleep 1秒鐘,防止優(yōu)先獲得時(shí)間片的線程直接申請到了另外1個(gè)互斥鎖,導(dǎo)致程序直接退出;
  4. t3時(shí)刻,主線程和子線程都想獲得對方手里的互斥鎖,但是對方都來不及釋放自己手里的鎖;
  5. t4時(shí)刻,主線程和子線雙雙進(jìn)入休眠。

【注意】為了保證主線程和子線程都能夠分別獲得鎖mutex1、mutex2,各自獲得鎖后一定要先sleep 1秒鐘,否則創(chuàng)建完子線程后,主線程還有一定的時(shí)間片,主線程會申請到鎖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\n"); 
 sleep(1);
 pthread_mutex_lock(&mutex1); 
 printf("new thread get mutex1\n"); 
 
 
 pthread_mutex_unlock(&mutex1);
 printf("new thread release mutex1\n");
 pthread_mutex_unlock(&mutex2); 
 printf("new thread release mutex2\n");
    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\n");
  sleep(1);
        pthread_mutex_lock(&mutex2);  
  printf("main thread get mutex2\n");
        pthread_mutex_unlock(&mutex2);
  printf("main thread release mutex2\n");
        pthread_mutex_unlock(&mutex1);
  printf("main thread release mutex1\n");
    }
    return 0;
 }             

編譯運(yùn)行

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

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

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


-THE END-



推薦閱讀


【1】SPI轉(zhuǎn)can芯片CSM300詳解、Linux驅(qū)動移植調(diào)試筆記
【2】到底什么是Cortex、ARMv8、arm架構(gòu)、ARM指令集、soc?一文幫你梳理基礎(chǔ)概念【科普】 必讀
【3】Linux面試題100道,看看會多少?必讀
【4】Modbus協(xié)議概念最詳細(xì)介紹必讀
【5】I2C基礎(chǔ)知識入門 必讀



本公眾號全部原創(chuàng)干貨已整理成一個(gè)目錄,點(diǎn)擊干貨」或者回復(fù) 1024 即可獲得

想加入嵌入式技術(shù)交流群請加一口君微信

一口君有問必答


主站蜘蛛池模板: 德庆县| 林州市| 商洛市| 长顺县| 阳泉市| 宜丰县| 桓台县| 西宁市| 洪湖市| 手游| 宣武区| 略阳县| 喀喇| 镇康县| 彭州市| 上犹县| 左权县| 镇巴县| 南郑县| 渑池县| 平谷区| 界首市| 桦南县| 万宁市| 五大连池市| 七台河市| 辽源市| 巫溪县| 厦门市| 汕头市| 鲁山县| 定兴县| 中西区| 富阳市| 濮阳县| 门头沟区| 保山市| 林芝县| 巴彦县| 巫山县| 晴隆县|