[Предыдущий: Быстрое перемещение по вашему коду с использованием поисковика] [Руководство по Qt Creator] [Следующий: Поддержка CMake в Qt Creator] Отладка с помощью Qt Creator
|
Платформа | Компилятор | Отладчик |
---|---|---|
Linux, Unixes, Mac OS | gcc | GNU Symbolic Debugger (gdb) |
Windows/MinGW | gcc | GNU Symbolic Debugger (gdb) |
Windows | Microsoft Visual C++ Compiler | Debugging Tools for Windows/Microsoft Console Debugger (CDB) |
Интерфейс позволит вам отлаживать программу построчно и или по каждой инструкции, прерывать запущенную программу, устанавливать точки останова, просматривать содержимое стека вызовов, локальных и глобальных переменных и т. д.
В Qt Creator сырая информация, предоставляемая отладчиком, отображается явным и лаконичным образом, упрощая процесс отладки.
В дополнение к базовой функциональности IDE: просмотр стека, просмотр локальных и наблюдаемых переменных, регистров и т.д., Qt Creator имеет дополнительные особенности, делая отладку приложений, основанных на Qt, проще. Интерфейс отладчика знает о внутреннем устройстве некоторых классов Qt, таких как QString, контейнеры QTL и, что особенно важно, QObject (и унаследованные от него классы). Таким образом, он может ясно представлять данные Qt.
Отладчик | Замечания |
---|---|
Gdb | Требует gdb версии 6.8. |
Debugging Tools for Windows | Использование этого отладчика требует установку пакета Debugging Tools for Windows 32-bit или 64-bit (версии 6.10 для 32-bit или 64-bit версии Qt Creator соответственно), который доступен для свободного скачивания с Microsoft Developer Network. Собранная версия Qt SDK for Windows будет использовать библиотеку если она присутствует в системе. При сборке Qt Creator с использованием компилятора Microsoft Visual C++, будет проверен путь "%ProgramFiles%\Debugging Tools for Windows" чтобы убедиться что все необходимые заголовочные файлы присутствуют. |
В режиме Отладка несколько прикрепляемых виджетов используется для взаимодействия с отлаживаемой программой. Часто используемые виджеты отображаются по умолчанию; используемые редко спрятаны. Для изменения настроек по умолчанию, выберите Отладка, а затем выберите Виды.
Здесь вы можете заблокировать и разблокировать положение ваших видов, а также показать или спрятать их. Среди видов, которые вы можете отобразить есть Точки останова, Дизассемблер, Модули, Регистры, Отладчик, Стек и Поток. Расположение ваших прикрепляемых виджетов будет сохранено для последующих сессий.
Точки останова показываются в виде Точки останова, который включён по умолчанию. Этот вид также доступен когда отладчик и отлаживаемая программа не запущены.
Точки останова представляют место или набор мест в коде, которые при выполнении прервут отлаживаемую программу и передадут управление пользователю. Пользователь может просмотреть состояние прерванной программы или продолжить выполнение построчно или непрерывно.
Обычно точки останова связаны с файлом исходных кодов и строкой или началом функции -- оба варианта доступны в Qt Creator.
Также прерывание программы на точке останова может быть запрещено при определённых условиях.
Вы можете установить точки останова:
Вы можете удалить точку останова:
Точки останова могут быть установлены и удалены перед тем как программа будет запущена или во время её работы под отладчиком. Также точки останова могут быть сохранены вместе с сессией.
Чтобы запустить программу под отладчиком выберите в меню Отладка пункт Начать отладку, или просто нажмите F5. Qt Creator проверит является ли собранная программа актуальной и пересоберёт её при необходимости. Отладчик получит контроль и запустит программу.
Замечание: Запуск программы в отладчике может занять заметное количество времени, обычно в диапазоне от нескольких секунд до нескольких минут, если используются сложные особенности (как QtWebKit).
После запуска программы она работает как обычно; тоже самое и с производительностью. Пользователь может прервать выполняемую программу выбрав Прервать из меню Отладка. Программа автоматически прерывается как только дойдет до точки останова.
Как только программа остановиться, Qt Creator:
Вы можете использовать виды отладчика для более подробного просмотра данных.
Чтобы закончить отладку нажмите Shift+F5. Строка кода может быть исполнена как одно целое с F10; чтобы выполнить функцию или подфункцию используйте F11. Также вы можете продолжить выполнение программы с помощью F5. Можно продолжить выполнение программы до окончания текущей функции или перепрыгнуть на произвольную позицию в текущей функции.
Когда отлаживаемая программа прерывается, Qt Creator отображает наследованные вызовы процедур, приводящие к текущему положению в следе стека вызовов. След стека строится из кадров стека вызовов, каждый из которых представляет конкретную функцию. Для каждой функции Qt Creator попытается получить имя файла и номер строки соответствующих файлов исходных кодов. Эти данные отображаются в виде Стек.
Так как стек вызовов, приводящий к текущему положению, может происходить из или проходить через код для которого нет отладочной информации, не все кадры стека могут иметь соответствующие положения в исходном коде. Эти кадры будут иметь серый цвет в виде Стек view.
Если вы щёлкните на кадре с известным положением в исходном коде, текстовый редактор перейдёт в соответствующее положение и обновит вид Локальные и наблюдаемые переменные, делая их видимыми как будто программа была прервана перед входом в функцию.
Если прервано многопоточное приложение, то можно использовать вид Поток или выпадающий список с именем Поток в строке состояния отладчика для переключения от одного потока к другому. Вид Стек будет настраивать себя соответственно.
Когда бы программа не остановилась под контролем отладчика, он получает информацию о верхнем кадре стека и отображает его в виде Локальные и наблюдаемые переменные. Он обычно включает информацию о параметрах функции в этом кадре, а также локальные переменные.
Составные переменные структур или классов в виде будут отображены как "раскрываемые". Щёлкните на "+" чтобы раскрыть элемент и показать все его члены. Помимо отображаемые значения и типа, пользователь может просмотреть и перейти к низкоуровневой компоновке данных объекта.
Замечание: |
Gdb, и поэтому отладчик Qt Creator, работают с оптимизированной сборкой на Linux и Mac OS X. Тем не менее, оптимизация может привести к изменению порядка инструкций и иногда даже к полному удалению некоторых локальных переменных. В этом случае вид Локальные и наблюдаемые переменные может показывать неожиданные данные. |
Отладочная информация, предоставляемая gcc не включает достаточной информации о времени, когда переменная инициализируется. Поэтому, Qt Creator не может сказать является ли содержимое начальной переменной "настоящими данными" или "начальным шумом". Если QObject появляется неинициализированным, его значение будет указано как "вне области". Тем не менее, не все неинициализированные объекты могут быть распознаны таким образом. |
Вид Локальные и наблюдаемые переменные также предоставляет доступ к наиболее мощной особенности отладчика: полное отображение данных, принадлежащих базовым объектам Qt. Для включения этой особенности, выберите Использовать помощник отладчика в меню Отладка. Вид Локальные и наблюдаемые переменные будут автоматически переупорядочены для отображения высокоуровневого вида объектов. Например, в случае с QObject, вместо отображения указателя на некоторую закрытую структуру данных, вы увидите список потомков, сигналы и слоты.
Аналогично, вместо отображения множества указателей и целых чисел, отладчик Qt Creator покажет содержимое QHash или QMap в упорядоченном виде. Также отладчик покажет данные доступа для QFileInfo и предоставит доступ к "реальному" содержимому QVariant.
Вид Локальные и наблюдаемые переменные может быть использован для изменения содержимого переменной простого типа данных, такого как int или float, когда программа прервана. Чтобы сделать это, щёлкните на столбце Значение, исправьте значение в встроенном редакторе и нажмите Enter (или Return).
Замечание: Набор наблюдаемых переменных сохраняется в вашей сессии.
По умолчанию, вид Модули спрятан, так как он полезен только с экспериментальным средством отложенной загрузки отладочной информации. Вы можете включить это свойство выбрав Быстрый запуск отладчика
С этим свойством, отладочная информация из библиотеки Qt не загружается при запуске программы, таким образом уменьшая время запуска для некоторых приложений. В этом случае вы можете использовать вид Модули для загрузки этой информации вручную при необходимости.
Замечание: В этом случае некоторые точки останова не могут быть вызваны отладчиком.
По умолчанию, виды Дизассемблер и Регистры спрятаны. Вид Дизассемблер отображает дизассемблированный код для текущей функции; вид Registers отображает текущее состояние регистров CPU. Оба вида полезны для низкоуровневых команд, таких как Перейти на одну инструкцию и Перейти через инструкцию.
При отладке Qt Creator динамически загружает вспомогательную библиотеку в вашу программу. Эта вспомогательная библиотека обеспечивает Qt Creator красивое отображение типов Qt и STL. Пакет Qt SDK уже содержит заранее скомпилированную библиотеку помощника отладчика. Чтобы создать библиотеку помощника отладчика, выберите Параметры... из меню Инструменты и перейдите на закладку Qt 4/Версии Qt. Так как внутренняя компоновка Qt может меняться для разных версий, библиотека помощника отладчика собирается для каждой версии Qt.
В нашем примере TextFinder мы считывали текстовый файл в QString, а замет отображали его в QTextEdit. Предположим, что вы хотите взглянуть на эту строку QString line и посмотреть какую информацию она хранит. Выполните шаги, описанные ниже, чтобы разместить точку останова и просмотреть данные объекта QString.
Установка точки останова Сначала, мы установим точку останова на строке где мы вызываем setPlainText() щёлкнув между номером строки и границей окна. Затем, выберите Начать отладку из меню Отладка или нажмите F5. |
Точки останова указываются в виде Точки останова, показанного ниже, в режиме Отладка. Если вы желаете удалить точку останова, просто щёлкните на ней правой кнопкой мыши и выберите Удалить точку останова из контекстного меню.
Чтобы просмотреть содержимое строки line, взгляните на вид Локальные или наблюдаемые переменные.
Предположим что мы изменили нашу функцию on_findButton_clicked() чтобы она перемещалась в начало документа и продолжала поиск после того, как курсор достигал конца документа. Эта функциональность может быть добавлена с помощью фрагмента кода, приведённого ниже:
void TextFinder::on_findButton_clicked() { QString searchString = ui->lineEdit->text(); QTextDocument *document = ui->textEdit->document(); QTextCursor cursor = ui->textEdit->textCursor(); cursor = document->find(searchString, cursor, QTextDocument::FindWholeWords); ui->textEdit->setTextCursor(cursor); bool found = cursor.isNull(); if (!found && previouslyFound) { int ret = QMessageBox::question(this, tr("End of Document"), tr("I have reached the end of the document. Would you like " "me to start searching from the beginning of the document?"), QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes); if (ret == QMessageBox::Yes) { cursor = document->find(searchString, QTextDocument::FindWholeWords); ui->textEdit->setTextCursor(cursor); } else return; } previouslyFound = found; }
Тем не менее, если вы соберёте и запустите этот код, приложение не будет работать правильно из-за логической ошибки. Чтобы обнаружить эту логическую ошибку, вы можете пройти через код, используя следующие кнопки:
[Предыдущий: Быстрое перемещение по вашему коду с использованием поисковика] [Руководство по Qt Creator] [Следующий: Поддержка CMake в Qt Creator]
Copyright © 2009 Nokia | Qt Creator 1.2.1 |
Попытка перевода Qt документации. Если есть желание присоединиться, или если есть замечания или пожелания, то заходите на форум: Перевод Qt документации на русский язык... Люди внесшие вклад в перевод: Команда переводчиков |