Next Previous Table of Contents
Отладочные макросы, предоставляемые библиотекой Qt, описаны на странице debug.html online-документации Qt, доступной по линку "Debugging Techniques" на странице с индексом Qt-документации.
Наиболее часто используемые макросы:
b - выражение типа boolean. Генерирует предупреждающее сообщение дебаггера, если равно false; p - указатель, который проверяется, если он равен нулю, то генерируется предупреждающее сообщение.
Подробности см. в online-документации Qt.
Внимание: Эта глава - копия документа о макросе KDEBUG, включенного в набор библиотек KDE и написанного Kalle Dalheimer's kalle@kde.org. Документ находится в файле kdebug.html.
Последнее изменение: Sat Sep 13 11:56:01 CEST 1997
Что такое KDebug
KDebug - набор макросов и функций, делающий более эффективным использование диагностических сообщений. Вы можете получать сообщения одного из четырех уровней строгости. Вы можете выбрать в процессе выполнения, куда должны выводиться диагностические сообщения, и какие из них вообще должны выводиться.
Макрос KDEBUG
Использование KDebug очень простое. Все, что вы должны сделать, это включить #include <kdebug.h> в начало каждого исходного файла, в котором вы хотите использовать диагностические сообщения, и выводить эти сообщения, вызывая макрос KDEBUG. Он ожидает 3 параметра. Первый - уровень безопасности; используйте следующие константы:
Второй параметр - это область. Область - часть KDE, которую вы определяете сами. Потом, в процессе выполнения, вы сможете выбрать, от какой области необходимо печатать диагностические сообщения. См. файл kdelibs/kdecore/kdebugareas.txt для получения списка уже назначенных диапазонов областей. Выберите область в диапазоне вашего приложения. Если ваше приложение еще не включено в этот список, и вы имеете доступ к CVS, вы можете назначить там область для своего приложения, иначе напишите мне. Вероятно, будет хорошей идеей определить символическую константу для области, которую вы хотите использовать, но это решаете вы.
Третий параметр, наконец, это текст, который вы хотите вывести. KDebug автоматически добавит логическое имя приложения, если вы производите вывод в файл, в stderr или в syslog. Всегда добавляется символ новой строки, вы не должны его использовать сами. Если вам нужны параметры, вы можете использовать один из макросов KDEBUG1, ..., KDEBUG9. Это позволит иметь от 1 до 9 дополнительных параметров. Синтаксис вывода абсолютно аналогичен printf, например, вы можете включать спецификации формата в ваше сообщение, которые заменяются дополнительными параметрами. Например:
KDEBUG3( <idx/KDEBUG_INFO/, kmail_composer, "Message no. %d to %s has %d bytes",
message_no, aMessage.to(), aMessage.length() );
KASSERT
Есть также макросы KASSERT, KASSERT1, ..., KASSERT9, которые работают так же, как их KDEBUG-аналоги, однако они имеют дополнительный первый параметр булевского типа. Только если он обращается в ложь, сообщение будет распечатано.
Примечание 1: вы не должны использовать ни KDEBUG, ни KASSERT до создания объекта KApplication.
Примечание 2: KDebug не предоставляет никаких возможностей интернационализации, поскольку он предназначен только для разработчиков. Если вы хотите информировать пользователя о нештатной ситуации (например, "этот файл защищен от записи"), используйте KMsgBox.
Опции компилятора
Вы не должны задавать никаких специальных ключей для компилятора при использовании KDebug. Но когда вы распространяете свое приложение (в основном это касается людей, которые создают .rpm или .deb пакеты), вы должны компилировать с ключом -DNDEBUG. Это просто удалит код дебаггера из вашего приложения и сделает его меньше и быстрее (например, оно будет использовать на 256K меньше памяти).
Как анализировать диагностические сообщения в процессе выполнения
Вы можете нажать Ctrl-Shift-F12 в любом приложении KDE в любое время, и появится диалог "Debug Settings". В нем вы сможете определить раздельно для каждого уровня строгости, что должно быть сделано с диагностическими сообщениями этого уровня. Возможны следующие настройки:
Кроме того, вы можете выбрать опцию "Прерывать на фатальных ошибках" ("Abort on fatal errors"). В этом случае при возникновении диагностического сообщения с уровнем "KDEBUG_FATAL" приложение завершит работу с кодом SIGABRT после вывода этого сообщения. Когда вы закроете диалог кнопкой OK, ваши настройки вступят в силу немедленно и сохранятся в конфигурационном файле вашего приложения. Имейте в виду, что эти установки специфичны для каждого приложения! При нажатии cancel все изменения будут утеряны, и будут возвращены предыдущие установки.
Next Previous Table of Contents