Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "WinAPI";
Текущий архив: 2004.07.04;
Скачать: [xml.tar.bz2];

Вниз

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

 
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 вся ветка

Форум: "WinAPI";
Текущий архив: 2004.07.04;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.46 MB
Время: 0.041 c
1-1087572230
alex870
2004-06-18 19:23
2004.07.04
Стили окна


14-1087291633
Layner
2004-06-15 13:27
2004.07.04
Простого клиента для 1С MS SQL 2000 базы, реально написать?


1-1087255908
Dmitry
2004-06-15 03:31
2004.07.04
Необходимо сделать объект прозрачным для событий.


8-1082600639
Boson
2004-04-22 06:23
2004.07.04
Фильтр НЧ


1-1087537714
Ш-К
2004-06-18 09:48
2004.07.04
Найти свойство по имени





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский