父线程和子线程互斥_两个线程,两个互斥锁,怎么形成一个死循环?

问题描述: 两个互斥锁,怎么形成一个死循环?

689b9f2fb08b7e686a44f5befd9de4af.png

粉丝的提问,必须安排。

两个线程,两个互斥锁如何形成死锁?

程序流程图如下:

7f706b3ae35d7ec30bb0774f16c96344.png

如上图所示:

  1. t0时刻,主线程创建子线程,并初始化互斥锁mutex1、mutex2;
  2. t1时刻,主线程申请到了mutex1、子线程申请到了mutex2;
  3. t2时刻,主线程和子线程都sleep 1秒钟,防止优先获得时间片的线程直接申请到了另外1个互斥锁,导致程序直接退出;
  4. t3时刻,主线程和子线程都想获得对方手里的互斥锁,但是对方都来不及释放自己手里的锁;
  5. t4时刻,主线程和子线双双进入休眠。

【注意】为了保证主线程和子线程都能够分别获得锁mutex1、mutex2,各自获得锁后一定要先sleep 1秒钟,否则创建完子线程后,主线程还有一定的时间片,主线程会申请到锁mutex2,无法形成死锁。

1ed711abab812231efca152bc89ee597.png

死锁

源码如下

#include #include #include #include    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) 

编译运行

6ea1ed80ecf8dab9622f09fb85e23211.png

从执行结果可以判断,主线程和子线程分别获得了互斥锁mutex1、mutex2,sleep 1秒后,他们都想再分别申请mutex2、mutex1,而双方都不想释放自己手中的锁,锁已形成了死锁,程序就一直处于休眠状态。

查看下该进程的线程

查看进程ID,为4204

19c888818c63a2714d66c7fbd13e627e.png

查看该进程创建的线程id:4204、4205。

6605f8c44dc0d6bd6abca5f18a997951.png

更多嵌入式linux 知识 请关注:一口Linux

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值