什么是死锁?死锁产生的条件?如何避免死锁?

两个或者多个并发的进程,如果每个进程持有某个资源的同时又在等待其他的进程释放资源导致程序无法向前推进,称这一组进程产生了死锁。通俗的来说就是两个或者多个进程无限期的阻塞,互相等待的状态。

死锁产生的四个条件:

1、互斥条件:一个资源只能被一个进程使用。

2、请求与保持条件:一个进程在请求其他资源的同时,对已经获得的资源保持不放。

3、不剥夺条件:进程资源没有使用完不能强行剥夺。

4、循环等待:若干个进程形成一个收尾相接的一个等待资源的状态。

如何避免死锁?

1、在使用之前进行判断,只允许不会产生死锁的进程申请资源。(银行家算法)

破坏死锁的四个条件之一,例如将资源或者进程进行编号,从而使他们按顺序执行等等。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值