在这段代码中死锁发生在哪里?JAVA
在线教程说 当死锁运行时,两个线程在试图调用bowBack时极有可能都会阻塞。两个块都不会结束,因为每个线程都在等待另一个退出在这段代码中死锁发生在哪里?JAVA,java,concurrency,locking,deadlock,Java,Concurrency,Locking,Deadlock,在线教程说 当死锁运行时,两个线程在试图调用bowBack时极有可能都会阻塞。两个块都不会结束,因为每个线程都在等待另一个退出 但我看不到任何相互依赖性。谁能解释一下僵局在哪里 这是一个经典的死锁,2个线程+2个锁 1) 螺纹1锁定阿尔方斯并移动至锁定加斯顿 2) 螺纹2锁定加斯顿并移动至锁定阿尔方斯 3) 螺纹1到达gaston,但被螺纹2和螺纹1锁定 4) 线程2到达alphonse,但它被线程1锁定并阻塞 在此处添加延迟以增加概率 public class Deadlock { s
但我看不到任何相互依赖性。谁能解释一下僵局在哪里 这是一个经典的死锁,2个线程+2个锁 1) 螺纹1锁定阿尔方斯并移动至锁定加斯顿 2) 螺纹2锁定加斯顿并移动至锁定阿尔方斯 3) 螺纹1到达gaston,但被螺纹2和螺纹1锁定 4) 线程2到达alphonse,但它被线程1锁定并阻塞 在此处添加延迟以增加概率
public class Deadlock {
static class Friend {
private final String name;
public Friend(String name) {
this.name = name;
}
public String getName() {
return this.name;
}
public synchronized void bow(Friend bower) {
System.out.format("%s: %s"
+ " has bowed to me!%n",
this.name, bower.getName());
bower.bowBack(this);
}
public synchronized void bowBack(Friend bower) {
System.out.format("%s: %s"
+ " has bowed back to me!%n",
this.name, bower.getName());
}
}
public static void main(String[] args) {
final Friend alphonse =
new Friend("Alphonse");
final Friend gaston =
new Friend("Gaston");
new Thread(new Runnable() {
public void run() { alphonse.bow(gaston); }
}).start();
new Thread(new Runnable() {
public void run() { gaston.bow(alphonse); }
}).start();
}
}
引文解释了这一点。
public synchronized void bow(Friend bower) {
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
...