当前位置: 首页 > 图灵资讯 > java面试题> 死锁条件和解决方式

死锁条件和解决方式

来源:图灵教育
时间:2024-06-03 13:21:55
死锁是指两个或两个以上进程在执行过程中,因争夺资源而造成的下相互等待的现象;

死锁的条件:

互斥条件:进程对所分配到的资源不允许其他进程访问,若其他进程访问该资源,只能等待至占有该资源的进程释放该资源。

请求与保持条件:进程获得一定的资源后,又对其他资源发出请求,阻塞过程中不会释放自己已经占有的资源。

非剥夺条件:进程已获得的资源,在未完成使用之前,不可被剥夺,只能在使用后自己释放。

循环等待条件:系统中若干进程组成环路,环路中每个进程都在等待相邻进程占用的资源。

解决方法:破坏死锁的任意一条件。

乐观锁,破坏资源互斥条件,CAS。

资源一次性分配,从而剥夺请求和保持条件、tryLock。

可剥夺资源:即当进程新的资源未得到满足时,释放已占有的资源,从而破坏不可剥夺的条件,数据库deadlock超时。

资源有序分配法:系统给每类资源赋予一个序号,每个进程按编号递增的请求资源,从而破坏环路等待的条件,转账场景。