死锁相关知识

死锁是什么

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


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

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

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


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

假设两个线程:

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

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


🔧 如何避免死锁:

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

🧪 在游戏测试中的表现:

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

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

相关推荐
虾..1 小时前
UDP协议
网络·网络协议·udp
独断万古他化3 小时前
Python+Pytest 接口自动化测试实战 —— 抽奖系统接口测试框架设计与实现
python·pytest·接口自动化·测试·allure·yaml·json schema
殷紫川5 小时前
全链路压测硬核实战:从方案落地、瓶颈根因定位到全链路性能优化
架构·测试
白宇横流学长6 小时前
基于UE引擎的格斗类游戏《SE2》的开发与实现
游戏
风酥糖6 小时前
Godot游戏练习01-第16节-游戏中的状态机
算法·游戏·godot
Java成神之路-6 小时前
DNS 与 CDN 底层原理深度剖析:从域名解析到内容分发全链路解析
网络·网络协议·tcp/ip
Predestination王瀞潞8 小时前
5.4.3 通信->WWW万维网内容访问标准(W3C):WWW(World Wide Web) 协议架构(分层)
前端·网络·网络协议·架构·www
今夕资源网9 小时前
开源轻量硬件监控软件LiteMonitor超小体积极致轻盈,可实时监测CPU、GPU、内存、磁盘、网络等系统性能,办公游戏皆适配,一键掌控电脑硬件状态
游戏·系统监控·软件·轻量·系统性能·硬件监控软件·硬件监控
huohaiyu9 小时前
HTTPS的加密流程
网络协议·http·https
花月C10 小时前
基于WebSocket的 “聊天” 业务设计与实战指南
java·网络·后端·websocket·网络协议