Nov 1, 2015
Heisen String
Here’s a good (and somewhat surprising) reason keep your toString
implementations free of side effects.
The program below will, as shown in the screen shot, output HeisenString[1]
in a normal run:
data:image/s3,"s3://crabby-images/64306/643067dea5b292bf93755a498bfa75123d44538a" alt=""
Now suppose we want to debug this program. We set a break point right before the System.out.println
and hit debug. Without really asking for it IntelliJ (and many other popular IDEs) show the string representation of the local variables:
data:image/s3,"s3://crabby-images/24882/24882f157be86a8b35dd7940f253219535d5f7f0" alt=""
This causes the toString
method to be called one extra time during debugging, and as a result the program outputs HeisenString[2]
:
data:image/s3,"s3://crabby-images/128ef/128ef6c2647ac01fc675642d80577c42bc43d39c" alt=""