Я столкнулся с этим example в учебнике Java по Java, в котором описывается Deadlock в многопоточных сценариях.Mutithreading с System.out.format и System.out.println
Таким образом, в этом примере я сделал следующие изменения в линии 17 и линии 18.
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) {
//My Changes
//System.out.format("%s: %s" + " has bowed to me!%n", this.name, bower.getName()); //Line 17
System.out.println(this.name + ": " + bower.getName() + " has bowed to me!"); //Line 18
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() {
@Override
public void run() {
alphonse.bow(gaston);
}
}).start();
new Thread(new Runnable() {
@Override
public void run() {
gaston.bow(alphonse);
}
}).start();
}
}
После выполнения этих изменений программы успешно завершено, не вызывая затор и распечатан следующим выходных
Alphonse: Gaston has bowed to me!
Gaston: Alphonse has bowed back to me!
Gaston: Alphonse has bowed to me!
Alphonse: Gaston has bowed back to me!
Так мой Вопрос в том, почему он так себя ведет? Как заявление println предотвратило тупик?
Я не вижу, как это будет. 'System.out.format' на самом деле ничего не отличается от' System.out.println' относительно блокировки. –
Не имеет значения - дело в том, что тупик зависит от чередования потоков, которые будут отличаться между прогонами. Если вы запускаете его несколько раз с помощью System.format, вы, вероятно, время от времени будете наблюдать за правильным результатом. И с помощью println вы также увидите прогоны, где программа выполняет тупик. – assylias
Действительно: первый вариант [отлично работает на ideone] (http://ideone.com/bV6nd8). –