什么是线程死锁
线程死锁是指 两个或多个线程 在执行过程中,因 争夺共享资源 而陷入 无限等待 的状态,导致所有相关线程都无法继续执行。
有两个线程,一个线程锁住了资源A,又想去锁定资源B,另外一个线程锁定了资源B又想去锁定资源A,两个线程都想去得到对方的资源,而又不愿释放自己的资源从而造成一种互相等待,无法执行的情况。
死锁的必要条件
- 互斥条件(Mutual Exclusion)
- 资源一次只能被一个线程占用(如锁、文件句柄)。
- 占有并等待(Hold and Wait)
- 线程已持有至少一个资源,同时等待获取其他被占用的资源。
- 非抢占条件(No Preemption)
- 已分配给线程的资源不能被强制剥夺,只能由线程主动释放。
- 循环等待(Circular Wait)
- 存在一个线程的循环等待链,每个线程都在等待下一个线程占用的资源。
只有这四个条件同时满足时,才会发生死锁。
常见的死锁场景
- 嵌套锁(Lock Ordering Problem)
- 线程A先锁住资源1,再尝试锁资源2;