java产生死锁的简单例子
class Test implements Runnable { private boolean flag; Test(boolean flag) { this.flag=flag; } public void run() { if (flag)//如果flag为ture,运行a,如果flag为false,运行B { while (true) { synchronized(MyLock.locka) { System.out.println("if locka"); synchronized(MyLock.lockb) { System.out.println("if lockb"); } } } } else { while (true) { synchronized(MyLock.lockb) { System.out.println("else lockb"); synchronized(MyLock.locka) { System.out.println("else locka"); } } } } } } class MyLock { public static final Object locka=new Object(); public static final Object lockb=new Object(); } class deadLockTest { public static void main(String[] args) { Test a=new Test(true); Test b=new Test(false); Thread t1=new Thread(a); Thread t2=new Thread(b); t1.start(); t2.start(); } }
运行结果如下,可以看到当只有第一个线程运行时,不会产生死锁问题,当t1线程完成第一个同步,获取到locka锁,CPU扫到t2线程,t2获取到lockb锁。这时,无论CPU扫到哪个线程,都无法进行下一个同步,因为t1和t2都无法获取下一个同步所需要的锁。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】Flutter适配HarmonyOS 5知识地图,实战解析+高频避坑指南
【推荐】凌霞软件回馈社区,携手博客园推出1Panel与Halo联合终身会员
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 智能桌面机器人:使用 .NET 为树莓派开发 Wifi 配网功能
· C# 模式匹配全解:原理、用法与易错点
· 记一次SSD性能瓶颈排查之路——寿命与性能之间的取舍
· 理解 .NET 结构体字段的内存布局
· .NET 9中的异常处理性能提升分析:为什么过去慢,未来快
· C# 模式匹配全解:原理、用法与易错点
· 杂七杂八系列----C#代码如何影响CPU缓存速度?
· C#/.NET/.NET Core优秀项目和框架2025年5月简报
· 鸿蒙仓颉语言开发实战教程:商城应用个人中心页面
· FFmpeg开发笔记(六十三)FFmpeg使用vvenc把视频转为H.266编码