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

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

死锁产生的四个条件:

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

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

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

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

如何避免死锁?

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

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

你可能感兴趣的:(java,开发语言)