|
84 / 84 / 19
Регистрация: 17.12.2007
Сообщений: 574
|
||||||
Логирование работы программы...!?07.06.2009, 16:02. Показов 5585. Ответов 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? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net
REST сервисы временно не работают, только через Web.
Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
|
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
|
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
|
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма).
На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
|
|
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ *
Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи
и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
|
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым.
Но восстановить их можно так.
Для этого понадобится консольная утилита. . .
|
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
|
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11
— это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
|