死锁定义:
死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程。(百度百科)
死锁产生的主要原因:
1.系统资源不足
2.进程运行推进的顺序不合适
3.资源分配不当。
产生死锁的四个必要条件:
1.互斥条件:一个资源每次只能被一个进程使用。
2.占有且等待:一个进程因请求资源二阻塞时,对已获得的资源保持不放。
3.不可强行占有:进程已获得资源,在未使用完之前,不可强行剥夺。
4.循环等待条件:若干进程之前行程一种头尾相接的循环等待资源关系。