【发布时间】:2010-12-06 11:16:43
【问题描述】:
我正在学习 Java 中的死锁,有来自 Sun 官方教程的示例代码:
Alphonse 和 Gaston 是朋友,并且 礼尚往来的大信徒。一个严格的 礼貌规则是当你鞠躬时 对朋友,你必须保持低头 直到你的朋友有机会 返回弓。不幸的是,这 规则不考虑 两个朋友可能会鞠躬 同时彼此。
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();
}
}
这是 Sun 的解释:
当死锁运行时,它非常 可能两个线程都会阻塞 当他们试图调用 bowBack。 两个区块都不会结束,因为 每个线程都在等待另一个 退出弓。
我似乎不太了解。当 alphonse.bow(gaston) 运行时, bow 方法被锁定。所以现在它会首先打印“Gaston has bowed to me!”。然后它会继续调用 bowBack,并锁定 bowBack。这怎么会导致死锁?我是否误解了调用同步方法时会发生什么?
如果有人能给我一个简单的解释,谢谢。
【问题讨论】:
-
看起来这里有很多正确的答案,但我认为将响应格式化为 2 个单独的列可能更有帮助,每个列代表一个不同的线程。这将真正证明可以同时运行 2 组指令。
-
我也有类似的困惑。感谢您的帖子和答案。
标签: java concurrency deadlock