多线程学习笔记(三)死锁

一、什么是死锁?

    线程死锁描述的是这样一种情况:多个线程同时被阻塞,他们中的一个或者全部都在等待某个资源被释放。由于线程无限期地阻塞,因此程序不可能正常终止。

二、产生死锁的条件

  1. 互斥条件:该资源任意一个时刻只由一个线程占用。
  2. 请求与保持条件:一个线程因请求资源而阻塞时,对已获得的资源保持不放。
  3. 不剥夺条件: 线程已获得的资源在末使用完之前不能被其他线程强行剥夺,只有自己使用完毕后才释放资源。
  4. 循环等待条件: 若干进程之间形成一种头尾相接的循环等待资源关系。

三、怎么避免死锁  

  1. 破坏互斥条件 :这个条件我们没有办法破坏,因为我们用锁本来就是想让他们互斥的(临界资源需要互斥访问)。
  2. 破坏请求与保持条件 :一次性申请所有的资源。
  3. 破坏不剥夺条件 :占用部分资源的线程进一步申请其他资源时,如果申请不到,可以主动释放它占有的资源。
  4. 破坏循环等待条件 :靠按序申请资源来预防。按某一顺序申请资源,释放资源则反序释放。破坏循环等待条件。

避免死锁常见的几个方法:

  1)避免一个线程同时获取多个锁。

  2)避免一个线程在所内同时占用多个资源,尽量保证每个锁只占用一个资源。

  3)尝试使用定时锁,使用lock.tryLock(timeout)来替代使用内部锁机制。

  4)对于数据库锁,加锁和解锁必须在一个数据库连接里,否则会出现解锁失败的情况、

posted @ 2020-12-27 19:12  迷思t无  阅读(101)  评论(0)    收藏  举报