C# 死锁的原理与排查方法详解

01

死锁的原理

     线程死锁是指由于两个或者多个线程互相持有对方所需要的资源,并且互相等待对方释放资源,导致这些线程都处于等待状态,无法继续执行。如果线程都不主动释放所占有的资源,将产生死锁。

如果死锁发生在UI线程,则会导致界面停止响应。

死锁的条件:

1.互斥条件:线程对于所分配到的资源具有排它性,即一个资源只能被一个线程占用,直到被该线程释放

2.请求和保持条件:一个线程因请求被占用资源而发生阻塞时,对已获得的资源保持不放。

3.不剥夺条件:任何一个资源在没被该线程释放之前,任何其他线程都无法对他剥夺占用

4.循环等待条件:当发生死锁时,所等待的线程必定会形成一个环路(类似于死循环),造成永久阻塞

02


死锁示例

e0478e37552150bd2140f3e5be383e49.png

03


如何避免死锁

方法一. 破坏互斥条件

方法二. 破坏环路等待条件

方法三. 破坏不剥夺条件

方法四. 破坏请求和保持条件

采用方法四举例:


f886bf151417bc8cf7b5e0fa5f454afa.png

04


排查方法

step1:在代码调试中,点击暂停按钮,然后vs就会自动定位到

0ffefa9f4fcca57e79820ef90977223f.png

step2:打开并行堆栈:然后点击指定方法名,进一步定位死锁语句

225752184553a9b138453e56cb1bd797.png

05


排查工具

可以采用第三方检测工具LockCop,检测死锁线程号,便于在非调试情况下查询死锁线程号,然后可以结合日志等信息排查死锁原因。

77fb3f2b9f30fd8b1c8d06ab47745b5f.png

技术群: 需要进技术群学习交流的请添加小编微信,切记备注:加群,对U上内容有什么疑问也可以直接和小编直接沟通交流!     

小编微信:mm1552923   

公众号:dotNet编程大全      

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值