Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.07.04;
Скачать: CL | DM;

Вниз

Мониторинг исключений   Найти похожие ветки 

 
Asdor ©   (2004-05-26 10:22) [0]

Здравствуйте, мастера. Подскажите пожалуйста, каким образом в программе можно сделать мониторинг возникаемых в ней исключений. Т.е. что исключение возникло по такому-то адресу. у него такой-то код ошибки и такое-то сообщение. Это исключение потом обработано в секции Except... end и благополучно убилось, или возбуждено снова.
Насколько я понимаю, что-то подобное и с записью в лог делал ExceptionMagic, но его у меня сейчас нет и скачать не могу (не нашел ни в яндексе ни в гугле, а сайт разработчика не работает...).

Спасибо.


 
Тимохов ©   (2004-05-26 10:40) [1]

Не очень понятно, зачем писать в лог исключение, которое "благополучно убилось"?

ИМХО:
1. Если убилось, ну и фиг с ним - зачем он в логе - такова логика работы (т.е. прибиваемое исключение не ошибка, а что-то другое), т.к. ошибочные исключения не прибиваются. Если вы прибиваете все исключения, то вы делаете большую ошибку :)))
2. Если не убилось, то оно дойдет до события Application.OnException. Там его и пишите в лог.


 
Asdor ©   (2004-05-26 10:50) [2]

В Application.OnException приходят не все исключения. В частности не приходят исключения из других потоков и исключения Com-объектов.
На данный момент я использую общего наследника для всех моих ком-объектов, где переопределяю SafeCallException, и там пишу в лог (соответсвенно для "не моих" COM-объектов это работать не будет...). Для обработки потоковых исключений - использую обертку на потоковую функцию. Для обработки assert - обертку на AssertErrorProc.
А ведь наверняка можно каким нибудь образом логировать все исключения из одного места, например перехватив вызов каких-нибудь системных процедур возбуждения/уничожения исключений. Вот этого и хотелось бы добиться.


 
Тимохов ©   (2004-05-26 11:00) [3]

в мониторинге вообще всех исключений я не силен.

Совет. Задайте этот вопрос в winapi.
Возможно, что как-то можно перехватывать работу с SEH (structure error handling). Имхо такой вопрос наиболее подходит для ответа знатокам winapi.


 
Asdor ©   (2004-05-26 11:18) [4]

Ну вот, ветку уже переместили... :)

Вобще-то не хотелось-бы заморачиваться с SEH. тем более в Delphi исключения хоть и проходят через нее, но далеко в глубинах модуля System и в Implementation - части...

Спасибо за ответы. посмотрим, что скажут в WinApi.


 
Игорь Шевченко ©   (2004-05-26 11:31) [5]

www.delphi-jedi.org, JCL, jcldebug.pas может чем-нибудь помочь.


 
Asdor ©   (2004-05-27 10:11) [6]

Огромное спасибо. Посмотрел. разбираюсь - очень интересно... :)



Страницы: 1 вся ветка

Текущий архив: 2004.07.04;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.027 c
6-1083942623
Sour
2004-05-07 19:10
2004.07.04
Изменение ip для сетевого подключения и рабочей группы (домена)


4-1085569904
Werewolf
2004-05-26 15:11
2004.07.04
Выполнение кода, когда мое приложение неактивно.


3-1086727961
Almaz
2004-06-09 00:52
2004.07.04
Создание таблиц с помощью ADO


9-1079558648
Sergeyshb
2004-03-18 00:24
2004.07.04
Создание игры "Другой мир"


14-1087153594
Девушка
2004-06-13 23:06
2004.07.04
Что такое эксплоит?