请选择行业
请选择职位
请选择省份
请选择城市

面试三连:什么是死锁?怎么排查死锁?怎么避免死锁?(上)

时间: 2021-05-25 10:18   作者: 不秃顶的Java程序员   点击次数: 
 
  在面试过程中,死锁也是高频的考点,因为如果线上环境很多发生了死锁,那真的出大事了。
  这次,我们就来系统地聊聊死锁的问题。
  · 死锁的概念;
  · 模拟死锁问题的产生;
  · 利用工具排查死锁问题;
  · 避免死锁问题的发生;
  01 死锁的概念
  在多线程编程中,我们为了防止多线程竞争共享资源而导致数据错乱,都会在操作共享资源之前加上互斥锁,只有成功获得到锁的线程,才能操作共享资源,获取不到锁的线程就只能等待,直到锁被释放。
  那么,当两个线程为了保护两个不同的共享资源而使用了两个互斥锁,那么这两个互斥锁应用不当的时候,可能会造成两个线程都在等待对方释放锁,在没有外力的作用下,这些线程会一直相互等待,就没办法继续运行,这种情况就是发生了死锁。
  举个例子,小林拿了小美房间的钥匙,而小林在自己的房间里,小美拿了小林房间的钥匙,而小美也在自己的房间里。如果小林要从自己的房间里出去,必须拿到小美手中的钥匙,但是小美要出去,又必须拿到小林手中的钥匙,这就形成了死锁。
  死锁只有同时满足以下四个条件才会发生:
  · 互斥条件;
  · 持有并等待条件;
  · 不可剥夺条件;
  · 环路等待条件;
  1.1 互斥条件
  互斥条件是指多个线程不能同时使用同一个资源。
  比如下图,如果线程 A 已经持有的资源,不能再同时被线程 B 持有,如果线程 B 请求获取线程 A 已经占用的资源,那线程 B 只能等待,直到线程 A 释放了资源。
  1.2 持有并等待条件
  持有并等待条件是指,当线程 A 已经持有了资源 1,又想申请资源 2,而资源 2 已经被线程 C 持有了,所以线程 A 就会处于等待状态,但是线程 A 在等待资源 2 的同时并不会释放自己已经持有的资源 1。
  1.3 不可剥夺条件
  不可剥夺条件是指,当线程已经持有了资源 ,在自己使用完之前不能被其他线程获取,线程 B 如果也想使用此资源,则只能在线程 A 使用完并释放后才能获取。
  1.4 环路等待条件
  环路等待条件指都是,在死锁发生的时候,两个线程获取资源的顺序构成了环形链。
  比如,线程 A 已经持有资源 2,而想请求资源 1, 线程 B 已经获取了资源 1,而想请求资源 2,这就形成资源请求等待的环形图。

打印本页 | 加入收藏

上一篇:软件测试&软件测试工程师     下一篇:【51讲堂】一文掌握大数据测试

关闭  
主要城市: 北京 上海 杭州 广州 南京 武汉 长沙
全部城市: