1. 死锁的概念
线程死锁描述的是这样一种情况:多个线程同时被阻塞,它们中的一个或者全部都在等待某个资源被释放。由于线程被无限期地阻塞,因此程序不可能正常终止。
好比是甲同学和乙同学在打扫卫生,甲同学拿着扫帚等乙同学的簸箕,而乙同学拿着簸箕在等甲同学的扫帚
2.死锁产生的条件
互斥条件:同一时刻一线程只能占用一个资源。
同一时刻,甲拿着扫帚,乙拿着簸箕。
请求与保持:一个线程因请求资源而阻塞时,对已获得的资源保持不放。
甲在等乙的簸箕,但甲不会让出自己的扫帚
不可剥夺:已获得的资源在为使用完时,其他线程不能强行剥夺。
甲拿着扫帚,但是甲不能去强抢乙拿的簸箕
循环等待
甲拿着扫帚在等乙的簸箕,而乙拿着簸箕等甲的扫帚,形成闭环
3.如何避免死锁呢?
打破产生条件即可
破坏互斥条件:无法被破坏,因为锁就是通过互斥来解决线程安全问题
破坏请求与保持条件:一次申请所有需要的资源
破坏不可剥夺条件:如果线程已占用部分资源,且他还要申请其他资源,如果申请不到,就主动释放它自己占有的资源
破坏循环等待条件:按照顺序申请资源,释放资源则逆序