|
84 / 84 / 19
Регистрация: 17.12.2007
Сообщений: 574
|
||||||
Логирование работы программы...!?07.06.2009, 16:02. Показов 5621. Ответов 8
Метки нет (Все метки)
Всем привет!!!
Имеется программулина, она постоянно делает некие действия, эти действия нужно записывать в лог, сейчас делаю так:
Минусы такого логирования на лицо - при любом вылете, ошибке программы, ничего не будет записано. Пока что есть 2 идеи: 1) после каждого действия писать в лог (но не накладно ли это будет??) 2) Сделать глобальное исключение, на все виды ошибок и вставить туда вышеуказанный код, таким образом при ошибках будет все же запись в логе, но не будет дапустим при отключении питания и т.д. Подскажите, как это по правильному делается, чтоб не изобретать велосипед??
0
|
||||||
| 07.06.2009, 16:02 | |
|
Ответы с готовыми решениями:
8
Зависание программы после return. Может быть, логирование поможет? Логирование работы программы
|
|
|
|
| 07.06.2009, 16:24 | |
|
Я логгирование делаю средствами Си - через FILE. В этом случае после каждой записи в файл делаю fflush, чтобы данный сразу в файле оказались. Причём всё это накрыто интерфейсом. Веду понятие "уровень отладки". Есть глобальная переменная, которая означает текущий уровень. И на каждый вызов записи в лог подаю параметром, при каких уровнях эту запись вести. Таким образом я могу ставить низкие уровни, при которых в лог попадает только основная информация или высокие - в лог попадают детали. Если интересно - могу модуль скинуть, правда там помойка, но суть выяснить несложно
Добавлено через 49 секунд Возможно, что для этого есть какие-то стандартные средства, но мне было впадлу с этим разбираться
1
|
|
|
|
|
| 07.06.2009, 16:49 | |
|
Набросал короткий демонстрационный пример
При запуске вылезет основная форма с двумя кнопками и отладочное окно При нажатии на первую кнопку в отладочном окне не произойдёт ничего. Далее в отладочном окне выставь debug level в значение "Minimal" и опять нажми на первую кнопку. Затем выставь debug level в "Full" и опять нажми первую кнупку. Результат скажет сам за себя. Параллельно вся информация сбрасывается в файл. Смысл это хреновины в том, чтобы можно было удалённо отладить программу. Т.е. у пользователей что-то ломается. Ты им говоришь при запуске программы нажмите на кнопку "Show Debug Window", выставьте Debug Level в значение "Full", начинайте работу со своими данными. Как только программа навернётся - пришлите мне файл _dbg_log.txt При нажатии нав торую кнопку идёт демонстрация ASSERT'а - т.е. внутреннего контроля. В рабочих версиях ASSERT определяется в пустышку "#define ASSERT(x)", при этом весь отладочный код в боевую версию программы не попадёт, но при этом в исходниках тебе ничего трогать не придётся (за исключением изменения макроса ASSERT)
3
|
|
|
84 / 84 / 19
Регистрация: 17.12.2007
Сообщений: 574
|
|
| 07.06.2009, 17:26 [ТС] | |
|
супер...
Спасиб огромное!
0
|
|
|
45 / 45 / 1
Регистрация: 23.05.2009
Сообщений: 92
|
||
| 21.07.2009, 17:04 | ||
|
Добавлено через 56 минут 12 секунд И приведите пожалуйста краткие примеры (несколь строк кода), которые логируются в файл.
1
|
||
|
MCSD: APP BUILDER
8795 / 1074 / 104
Регистрация: 17.06.2006
Сообщений: 32,602
|
|
| 21.07.2009, 17:11 | |
|
2
|
|
|
Задающий вопросы (%
16 / 15 / 0
Регистрация: 09.05.2009
Сообщений: 168
|
|
| 14.11.2009, 22:10 | |
|
К сожалению вылетает ошибка:
[BCC32 Error] FormDebug.h(51): E2447 'DebugLevel' must be a previously defined enumeration tag Не по теме:никто не знает почему после установки Windows 7,все русские комментарии аброкадаброй отображаются?
0
|
|
|
|
|
| 14.11.2009, 23:46 | |
|
Перед описанием класса TDebugForm воткни строку "enum DebugLevel;" или вообще всё описание enum'а (оно идёт чуть ниже описания класса TDebugForm) перенеси, чтобы перед классом было. Я так понимаю, что у тебя Borland-2009, видимо он более строго к синтаксису относится, чем 2007
1
|
|
| 14.11.2009, 23:46 | |
|
Помогаю со студенческими работами здесь
9
Как реализовать логирование работы скрипта Python Как реализовать логирование программы? Логирование при закрытии программы вручную Логирование: скажется ли постоянно открытый поток для записи на скорости работы Как вывести время работы программы ПОСЛЕ завершения работы progressBar? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 30.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
|
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO
Апнулись до NET10.
Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта
так и в интерактивном режиме. из сложностей - чисто функциональный подход.
Решил. . .
|
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2.
Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники".
В. . .
|
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии.
. . .
|
|
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2.
При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
|
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут.
https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc
Первый документ красиво выглядит, но без схемы.
Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
|
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере".
Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
|
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти".
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2.
В качестве источника данных. . .
|