死锁相关知识

死锁是什么

死锁(Deadlock)是指两个或多个进程(或线程)在执行过程中,因为互相等待对方释放资源,导致永远无法继续执行的状态。


✅ 死锁的形成条件(必须同时满足以下四个):

  1. 互斥:资源一次只能被一个进程占用。
  2. 占有且等待:一个进程持有一部分资源,同时又在等待其他资源。
  3. 不剥夺:已分配的资源不能被强制回收,只能由占有者释放。
  4. 循环等待:多个进程形成一种资源循环等待关系。

只要这四个条件都成立,系统就可能出现死锁。


🎮 举个简单的例子(游戏开发中常见的场景):

假设两个线程:

  • 线程A 先拿到了资源1,然后想拿资源2;
  • 线程B 先拿到了资源2,然后想拿资源1。

此时两个线程都在等待对方释放资源,谁也无法继续执行,程序就卡死了,这就是死锁。


🔧 如何避免死锁:

  1. 避免循环等待:统一资源申请顺序。
  2. 使用超时机制:获取资源时设置超时时间,超时就放弃,避免一直等待。
  3. 使用资源调度算法:如银行家算法,提前评估系统资源状态。
  4. 尽量减少锁粒度:用更细的锁、减少持锁时间。

🧪 在游戏测试中的表现:

  • 某些界面卡住不动;
  • 某些多人游戏房间无法开始战斗;
  • 服务端CPU飙高但没有响应;
  • 日志中反复出现线程等待或资源请求。

总结一句话:
死锁是一种程序互相"卡脖子"的状态,既不报错也不崩溃,但永远无法继续运行。 测试人员发现这种情况后,要重点看线程堆栈、日志锁等待记录,并配合开发定位原因。

相关推荐
zz-zjx3 小时前
进程与线程详解, IPC通信与RPC通信对比,Linux前台与后台作业
linux·网络协议·rpc
迈威通信8 小时前
迈威通信从送快递角度教你分清网络二层和三层
网络·网络协议·智能路由器·信息与通信
wanhengidc9 小时前
云手机运行是否消耗自身流量?
运维·科技·安全·游戏·智能手机
郝亚军9 小时前
根据Sec-WebSocket-Key计算Sec-WebSocket-Accept
网络·websocket·网络协议
Kaede69 小时前
深入探索 WebSocket:构建实时应用的核心技术
网络·websocket·网络协议
wanhengidc9 小时前
云手机将要面临的挑战有哪些?
运维·网络·安全·游戏·智能手机
gou1234123412 小时前
Golang之GoWorld深度解析:基于Go语言的分布式游戏服务器框架
分布式·游戏·golang
霍格沃兹_测试12 小时前
Browser Use 浏览器自动化 Agent:让浏览器自动为你工作
人工智能·测试
web前端神器13 小时前
记录一下node后端写下载https的文件报错,而浏览器却可以下载。
网络协议·http·https
金山电脑医生13 小时前
DirectX修复必备指南:解决DLL缺失与游戏崩溃的5种方法
游戏·dll丢失·dll缺失