【多线程】多线程死锁及解决方法

本文探讨了在同一函数中使用两个互斥量(mutex)导致的无限等待问题,并解释了互斥量嵌套可能导致的死锁现象,强调了在多线程环境下正确使用互斥量的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 互斥量嵌套

两个互斥量在同一个函数(或线程)中使用,在调试时发现如果两个互斥量嵌套使用,会出现无限等待问题
如,两个互斥量 A、 B 
fun(){ 
    pthread_mutex_lock(A); 
    ..... 
    pthread_mutex_lock(B); 
    ...... 
    pthread_mutex_unlock(B); 
    ...... 
    pthread_mutex_unlock(A); 

如果这样写,只能调用该函数一次,第一次运行是正常的,第二次再调用时,始终停留在pthread_mutex_lock(A)这里,怎么回事?

mutex持有后再去持有不同的mutex,这个是不允许的,在设计时应该尽量避免这种情况的发生(因为其中会涉及到线程优先级变更的问题)?

簡單點就是需要多個mutex時,按順序持有mutex。需可查閱os相關書籍,這是一個典型死鎖來源?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值