Из книги шаблонов проектирования Head First , одноэлементный шаблон с блокировкой с двойной проверкой был реализован следующим образом:
public class Singleton {
private volatile static Singleton instance;
private Singleton() {}
public static Singleton getInstance() {
if (instance == null) {
synchronized (Singleton.class) {
if (instance == null) {
instance = new Singleton();
}
}
}
return instance;
}
}
Я не понимаю, почему volatile
становится использовал. Разве использование volatile
не противоречит цели использования блокировки с двойной проверкой, то есть производительности?