使用内部类实现线程死锁
线程死锁会不断消耗资源,禁止使用。本文纯属娱乐。
在使用synchronized嵌套的时候很容易出现死锁现象,因此慎用synchronized嵌套。
public class TestDeadLock {
public static void main(String [] args) {
new TestDeadLock().show();
}
public void show() {
DeadLock dl = new DeadLock();
Thread tdl1 = new Thread(dl, "老王");
Thread tdl2 = new Thread(dl, "小王");
tdl1.start();
tdl2.start();
}
class DeadLock implements Runnable{
private Object key1 = new Object();
private Object key2 = new Object();
private boolean isFlag;
@Override
public void run() {
if(!isFlag) {
isFlag = true;
synchronized(key1) {
System.out.println(Thread.currentThread().getName() + "拿到了key1");
synchronized(key2) {
System.out.println(Thread.currentThread().getName() + "拿到了key2");
}
}
}else {
isFlag = false;
synchronized(key2) {
System.out.println(Thread.currentThread().getName() + "拿到了key2");
synchronized(key1) {
System.out.println(Thread.currentThread().getName() + "拿到了key1");
}
}
}
}
public boolean isFlag() {
return isFlag;
}
public void setFlag(boolean isFlag) {
this.isFlag = isFlag;
}
}
}
【推荐】AI 的力量,开发者的翅膀:欢迎使用 AI 原生开发工具 TRAE
【推荐】2025 HarmonyOS 鸿蒙创新赛正式启动,百万大奖等你挑战
【推荐】博客园的心动:当一群程序员决定开源共建一个真诚相亲平台
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步