ilostmyid2 Ответов: 2

Как узнать, где произошло исключение?


Я получаю следующее исключение и не знаю, в какой строке оно происходит, чтобы я его разрешил:
Первое случайное исключение типа "System.NullReferenceException" произошло в UserControls.dll

Что я уже пробовал:

Мне нужно знать, какая строка кода вызывает отображение сообщения в окне вывода, и я понятия не имею.

F-ES Sitecore

Добавьте обработку исключений и ведение журнала в методы и захватите трассировку стека. Вы получаете не код при попытке

someObject.SomeProperty

где "someObject" - это null.

ilostmyid2

конечно, но не знаю, где это происходит в решении с большим количеством проектов. так что я не знаю, куда поставить блок try/catch. вот в чем проблема.

Eric Lynch

Просто добавьте блок" последний шанс " try/catch. Где именно, зависит от вида применения. Для большинства типов вы можете разместить его вокруг логики в основном методе. Для веб-приложений это немного другая, но та же концепция.

Или вы можете просто запустить его в отладчике, который обычно прерывается на нарушающей строке, когда возникает исключение.

ilostmyid2

я думаю, тут есть проблема. исключение выбрасывается где-то в коде, но оно улавливается там, не будучи обработанным. так что я не могу его найти. исключение приглушается таким образом.

2 Ответов

Рейтинг:
2

jsc42

try
{
   // code that may raise an exception
}
catch (NullReferenceException ex)
{
   msgbox($"{ex.Message} {ex.StackTrace}")
}



Ex.StackTrace покажет, где произошла ошибка (ВКЛ. строку no)


ilostmyid2

проблема в том, что я не могу найти блок кода, который вызывает исключение, потому что он отключен.

Рейтинг:
19

OriginalGriff

Самый простой способ - просто использовать отладчик - когда он попадет в необработанное исключение, он остановится и покажет вам точно, что он выполнял, - затем вы можете использовать трассировку стека для работы с вашим кодом (если это происходит в фреймворке по какой-либо причине).

Это одна из самых распространенных проблем, которые нам задают, и это также та, на которую мы меньше всего готовы ответить, но вы больше всего готовы ответить сами.

Позвольте мне просто объяснить, что означает ошибка: вы пытались использовать переменную, свойство или возвращаемое значение метода, но оно содержит null - что означает, что в переменной нет экземпляра класса.
Это немного похоже на карман: у вас есть карман в рубашке, который вы используете, чтобы держать ручку. Если вы сунете руку в карман и обнаружите, что там нет ручки, вы не сможете подписать свое имя на листе бумаги - и вы получите очень смешные взгляды, если попытаетесь! Пустой карман дает вам нулевое значение (здесь нет ручки!), поэтому вы не можете сделать ничего, что обычно делали бы, когда вы извлекли свою ручку. Почему он пуст? Вот в чем вопрос - может быть, вы забыли взять ручку, когда уходили из дома сегодня утром, или, возможно, вы оставили ручку в кармане вчерашней рубашки, когда снимали ее вчера вечером.

Мы не можем сказать, потому что нас там не было, и, что еще важнее, мы даже не можем видеть вашу рубашку, не говоря уже о том, что находится в кармане!

Вернемся к компьютерам, и вы каким - то образом сделали то же самое-и мы не можем увидеть ваш код, а тем более запустить его и узнать, что содержит null, когда это не должно быть.
Но вы можете - и Visual Studio поможет вам здесь. Запустите свою программу в отладчике, и когда она выйдет из строя, VS покажет вам строку, в которой она обнаружила проблему. Затем вы можете начать просматривать различные его части, чтобы увидеть, какое значение равно null, и начать просматривать свой код, чтобы узнать, почему. Поэтому поставьте точку останова в начале метода, содержащего строку ошибки, и снова запустите программу с самого начала. На этот раз VS остановится перед ошибкой и позволит вам изучить, что происходит, пройдя через код, глядя на ваши значения.

Но мы не можем этого сделать - у нас нет вашего кода, мы не знаем, как его использовать, если бы он у нас был, у нас нет ваших данных. Так что попробуйте - и посмотрите, сколько информации вы можете узнать!


ilostmyid2

я читал об этом в интернете, но, как я уже сказал Эрику Линчу, исключение приглушено, и я не могу его найти.

OriginalGriff

Если вы получаете исключение, то оно не "приглушено", что бы это ни значило. И запуск его в отладчике остановит ваш код в строке, на которой происходит исключение. Если это находится в системном коде, то он либо загрузит системный код из справочных источников, либо покажет последнюю строку вашего кода, которая вызвала системный код.

Вы также можете сделать это еще более очевидным: в Visual Studio перейдите в меню отладки, выберите пункт "исключения..." и поставьте галочки в каждом поле, прежде чем нажать кнопку "ОК". Теперь отладчик будет останавливаться для каждого исключения, даже если у вас есть обработчик для него.

Мы не можем сделать это за вас: вам нужен ваш код, запущенный в отладчике, чтобы узнать, что происходит, а у нас нет доступа к нему, и это данные!

ilostmyid2

спасибо за трюк, я собираюсь его проверить.
но я не получаю исключения, это была проблема. это просто сообщается в окне вывода, и код продолжает работать, так как не было никаких исключений.

OriginalGriff

Если об этом сообщается в окне вывода, то он перехватывается и либо отлаживается.WriteLine или консоль.WriteLine используется, чтобы показать вам - но галочка во всех полях должна означать, что VS останавливается на ней.

ilostmyid2

действительно, я искал этого. исключение было отключено меню отладки. пожалуйста, поставьте это как решение, чтобы я мог принять его.

OriginalGriff

Просто оставь все как есть - это часть разговора!