Согласно JSR-133 неизменяемые объекты являются потокобезопасными и не нуждаются в синхронизации. Однако возможно обновить значения конечных полей с помощью отражения:
package com.stackoverflow;
import java.lang.reflect.Field;
public class WhatsGoingOn {
static class Immutable {
private final int value;
public Immutable(int value) {
this.value = value;
}
public int getValue() {
return value;
}
}
public static void main(String[] args) throws NoSuchFieldException, SecurityException, IllegalArgumentException, IllegalAccessException {
final Immutable immutable = new Immutable(Integer.MIN_VALUE);
final Field f = Immutable.class.getDeclaredField("value");
f.setAccessible(true);
System.out.println(immutable.getValue());
f.set(immutable, Integer.MAX_VALUE);
System.out.println(immutable.getValue());
}
}
Учитывая количество фреймворков (Spring и Hibernate - всего лишь несколько), которые полагаются на размышления, мне любопытно, что спецификация говорит об этом сценарии. Например. если я поместил обновление поля в синхронизированный блок, который обеспечит видимость в других потоках, или значение будет кэшироваться в регистрах по спецификации для окончательного.
http://download.oracle.com/otndocs/jcp/memory_model-1.0-pfd-spec-oth-JSpec/