Многие объяснения уже присутствуют, чтобы объяснить, как это происходит и как это исправить, но вы также должны следовать рекомендациям, чтобы избежать NullPointerException
вообще.
См. также: A хороший список лучших практик
Я бы добавил, очень важно, хорошо использовать модификатор final
. Использование "окончательной" модификатор, когда это применимо в Java
Сводка:
final
для обеспечения хорошей инициализации. @NotNull
и @Nullable
if("knownObject".equals(unknownObject)
valueOf()
поверх toString (). StringUtils
StringUtils.isEmpty(null)
. Кажется, что это не может быть сделано тот путь. Это только обеспечит метаинформацию о методе и его параметрах. Не фактическое значение во время стека вызовов.
Некоторые предлагают получить Ваши классы от ContextBoundObject и используют IMessageSink, который будет уведомлен от всех вызовов метода и значений параметров. Это обычно используется для Дистанционная работа.NET .
Другое предложение могло бы быть должно записать отладчик. Это - то, как IDE получает свою информацию. Microsoft имеет , Mdbg которого можно получить исходный код. Или запишите профилировщик CLR .