A field member is suddenly becoming a null value during android runtime on Nexus 5x devices
public class TestA
{
// While not final, could have been final as no writes other than in the constructor
private Object impossibleToBeNull;
public TestA()
{
impossibleToBeNull = new Object();
}
public void method1()
{
impossibleToBeNull.toString(); // Null pointer occurs here
}
}
Somehow, during the runtime of my Android App, a NullPointerException is thrown in my actual equivalent of "method1" from the simplified class example above. I cannot identify any valid situation in which this variable would be null, as it is constructed in the TestA constructor, and if it were to fail in its construction, there would not be a TestA instance to call "method1" on.
The only additional information I have is that the occurrences happen on dispatchTouchEvent, and specifically only on a Nexus 5x device(Have been unable to reproduce it on other devices).
There appears to be a strange behavior on the Nexus 5x where if you bring your two fingers together in a single gesture and hold them together in just the right fashion, thousands of touch inputs events go off. This occurs both inside apps and on the home screen, and is not limited to any one app. This may be related, or it may just be doing enough input actions for the reproduction.
It seems that @yegodm was correct in his comment on my post. According to Oracle docs Because the reference to my "TestA" object is set from another thread, the nonfinal member might not yet be published to the main memory. Their example 17.5-1 shows this nicely.