Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/26: Рейтинг темы: голосов - 26, средняя оценка - 4.62
 Аватар для FreeWay
84 / 84 / 19
Регистрация: 17.12.2007
Сообщений: 574

Логирование работы программы...!?

07.06.2009, 16:02. Показов 5585. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет!!!
Имеется программулина, она постоянно делает некие действия, эти действия нужно записывать в лог, сейчас делаю так:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
void __fastcall TMain_f::FormClose(TObject *Sender, TCloseAction &Action)
{
 FileLog->LoadFromFile(ExtractFilePath(Application->ExeName)+"CSO.LOG");
 RzRichEditLog->Lines->Add(GetDate(2)+"   Выход из программы");
 RzRichEditLog->Lines->Add("-------------------------------------------------------------------------");
  int count=RzRichEditLog->Lines->Count, i=0;
  while (count!=i)
    {
      FileLog->Add(RzRichEditLog->Lines->operator [](i));
      i++;
    }
 FileLog->SaveToFile(ExtractFilePath(Application->ExeName)+"CSO.LOG");
}
то-есть данные работы в лог сохраняются только после закрытия программы.
Минусы такого логирования на лицо - при любом вылете, ошибке программы, ничего не будет записано.


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

Подскажите, как это по правильному делается, чтоб не изобретать велосипед??
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.06.2009, 16:02
Ответы с готовыми решениями:

Зависание программы после return. Может быть, логирование поможет?
Приветствую! Программа виснет после return одной функции. Я останавливался там дебаггером, return проходит, после этого жму F8, в этот...

Логирование работы программы
Всем доброго времени суток! Столкнулся с проблемой - мне дали программу и сказали разбирайся. Там полно различных функций и...

Логирование программы
Добрый день! Возникла необходимость прологировать некую программу. сам лог понятен procedure TStdMainForm.Log (Text: string); var F:...

8
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
07.06.2009, 16:24
Я логгирование делаю средствами Си - через FILE. В этом случае после каждой записи в файл делаю fflush, чтобы данный сразу в файле оказались. Причём всё это накрыто интерфейсом. Веду понятие "уровень отладки". Есть глобальная переменная, которая означает текущий уровень. И на каждый вызов записи в лог подаю параметром, при каких уровнях эту запись вести. Таким образом я могу ставить низкие уровни, при которых в лог попадает только основная информация или высокие - в лог попадают детали. Если интересно - могу модуль скинуть, правда там помойка, но суть выяснить несложно

Добавлено через 49 секунд
Возможно, что для этого есть какие-то стандартные средства, но мне было впадлу с этим разбираться
1
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
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)
Вложения
Тип файла: rar TestLog.rar (27.6 Кб, 228 просмотров)
3
 Аватар для FreeWay
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
Цитата Сообщение от Evg Посмотреть сообщение
Набросал короткий демонстрационный пример

При запуске вылезет основная форма с двумя кнопками и отладочное окно
При нажатии на первую кнопку в отладочном окне не произойдёт ничего. Далее в отладочном окне выставь debug level в значение "Minimal" и опять нажми на первую кнопку. Затем выставь debug level в "Full" и опять нажми первую кнупку. Результат скажет сам за себя. Параллельно вся информация сбрасывается в файл. Смысл это хреновины в том, чтобы можно было удалённо отладить программу. Т.е. у пользователей что-то ломается. Ты им говоришь при запуске программы нажмите на кнопку "Show Debug Window", выставьте Debug Level в значение "Full", начинайте работу со своими данными. Как только программа навернётся - пришлите мне файл _dbg_log.txt

При нажатии нав торую кнопку идёт демонстрация ASSERT'а - т.е. внутреннего контроля. В рабочих версиях ASSERT определяется в пустышку "#define ASSERT(x)", при этом весь отладочный код в боевую версию программы не попадёт, но при этом в исходниках тебе ничего трогать не придётся (за исключением изменения макроса ASSERT)
А нет случайно примера для Microsoft Visual Studio, а то файл vcl.h не находит(.

Добавлено через 56 минут 12 секунд
И приведите пожалуйста краткие примеры (несколь строк кода), которые логируются в файл.
1
MCSD: APP BUILDER
 Аватар для IT_Exp
8795 / 1074 / 104
Регистрация: 17.06.2006
Сообщений: 32,602
21.07.2009, 17:11
http://logging.apache.org/log4cxx/index.html
2
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
03.08.2009, 21:11
Цитата Сообщение от Skirmisher Посмотреть сообщение
И приведите пожалуйста краткие примеры (несколь строк кода), которые логируются в файл.
Почитай, как делается запись текста в файл. Это и есть логгирование. А над этим строится обёртка, наиболее удобная для твоих целей
1
Задающий вопросы (%
 Аватар для KTYJIX
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
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
14.11.2009, 23:46
Перед описанием класса TDebugForm воткни строку "enum DebugLevel;" или вообще всё описание enum'а (оно идёт чуть ниже описания класса TDebugForm) перенеси, чтобы перед классом было. Я так понимаю, что у тебя Borland-2009, видимо он более строго к синтаксису относится, чем 2007
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.11.2009, 23:46
Помогаю со студенческими работами здесь

Как реализовать логирование работы скрипта Python
Необходимо работу скрипта Python (stdout, stderr) логировать в файл. Если отдельно перенаправить stderr и stdout в файл, то, насколько...

Как реализовать логирование программы?
Есть программа, которая работает некоректно: в какой-то моментпередаются неправильные значения. Чтобы понять где именно ошибка, хотелось бы...

Логирование при закрытии программы вручную
Здравствуйте друзья. Есть мною написанная программа. В программе пишется номера по порядку. Далее программа заходит на сайт через...

Логирование: скажется ли постоянно открытый поток для записи на скорости работы
Здравствуйте. В программе необходимо логирование. Сделал пока так: в начале работы открыл файл, в процессе - пишу в него,а в конце работы...

Как вывести время работы программы ПОСЛЕ завершения работы progressBar?
У меня почему-то сначала выводится время в MessageBox, а затем уже завершает свою работу progressBar, а мне нужно наоборот. ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
моя боль
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 из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru