面经--死锁的概念

今天被问到了死锁发生的条件,说实话这种概念性的东西之前都是不怎么care的,所以没有答上来,所以特意开篇文章来帮助跟我一样的选手!

一、什么是线程死锁

是指两个或两个以上的线程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去。

二、线程死锁怎么发生

发生死锁的情况一般是两个对象的锁相互等待造成的。

三、死锁发生的条件

1、互斥条件:所谓互斥就是进程在某一时间内独占资源。
2、请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
3、不剥夺条件:进程已获得资源,在末使用完之前,不能强行剥夺。
4、循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。

死锁通常是一个线程锁定了一个资源A,而又想去锁定资源B;在另一个线程中,锁定了资源B,而又想去锁定资源A以完成自身的操作,两个线程都想得到对方的资源,而不愿释放自己的资源,造成两个线程都在相互等待,造成了无法执行的情况。

四、怎么解决线程死锁

当几个线程都要访问共享资源A、B、C时,保证使每个线程都按照同样的顺序去访问它们,比如都先访问A,在访问B和C。

你可能感兴趣的:(面经--死锁的概念)