程序死锁原因

x33g5p2x  于2022-03-05 转载在 其他  
字(0.6k)|赞(0)|评价(0)|浏览(228)

一 交叉锁可导致程序出现死锁 

线程 A 持有 R1 的锁等待获取 R2 锁,线程 B 持有 R2 的锁等待获取 R1 的锁,这种情况最容易导致程序发生死锁。

二 内存不足

当并发请求系统可用内存时,此时系统内存不足,则可能出现死锁。例如:两个线程 T1 和 T2,执行某个任务,两个线程中,T1已经获取了 10MB 内存,T2 已经获取了 20MB内存,如果每个线程都需要30MB的内存,但是剩余可用内存接近为0MB,两个线程都在等待对方释放完内存才能继续工作,这种情况也会发生死锁。

三 一问一答的数据交换

服务端开启某个端口,等待客户端访问,客户端发送请求立即等待接收,由于某种原因,服务端无法接受客户端请求,此时服务端一直等待客户端请求,客户端也一直等待服务端应答,两者相互等待,陷入死锁。

四 数据库锁

无论是数据库表别的锁,还是行级的锁,比如某个线程进入了事务,准备执行 update 语句,突然退出,其他线程访问该数据库时都会陷入死锁。

五 文件锁

某个线程获得了文件锁意外退出,其他读取该文件的线程也将会进入死锁直到系统释放文件句柄资源。

六 死循环引起的死锁

程序由于代码原因或者对某些异常处理不得当,进入死循环,虽然查看线程堆栈信息不会发现任何死锁的迹象,但是程序不工作, CPU 占有率又居高不下,这种死锁一般称为系统假死,是一种最为致命也是最难排查的死锁现象,由于重现困难,进程对系统资源的使用量又达到了极限,想要做 dump 有时候也是非常困难的。

相关文章