If variables in Java are accessed from multiple threads, one must ensure that they are safely published. This usually means using synchronizedor volatile.
I have got the impression, that some of my colleagues do not take this issue seriously, since they “never heard of volatile before and their programs have worked for years”.
So my question is:
Can someone provide an example Java program/snippet, that reliably shows data visibility problems.
I think running a program and seeing the unexpected NPE or stale variable value would help more, than just theoretic explanations, that cannot be demonstrated.
Thanks a lot for your help!
Update: Just to emphasis the point again. I have read Java Concurreny in Practice and know examples that theoretically have visibility issues. What I am looking for is a way to actually demonstrate them. I am not sure, that this is actually possible, but maybe there is a jvm configuration or something similar that allows it.
By modifying the example here by removing operations I have come up with an example that consistently fails in my environment (the thread never stops running).
Note that this type of problems are quite dependent on the compiler/runtime/system. In particular the compiler can determine to add instructions to read the variable from memory even if it is not volatile –so the code would work–, the vm and jit can optimize away the reads from memory and use only registers, and even the processor can reorder instructions –that would not affect this case, but in other multithreaded cases it can affect the perceived state from other threads if more than one variable are modified.