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

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

07.06.2009, 16:02. Показов 5621. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Перемещение выделенных строк ТЧ из одного документа в другой
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. В качестве источника данных. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru