Gcov - Gcov
Gcov это покрытие исходного кода анализ и ведомость за ведомостью профилирование инструмент. Gcov генерирует точный подсчет количества выполнений каждого оператора в программе и аннотирует исходный код добавить приборы. Gcov поставляется как стандартная утилита с Коллекция компиляторов GNU (GCC) люкс.[1]
Утилита gcov дает информацию о том, как часто программа выполняет сегменты кода.[2] Он создает копию исходного файла с пометкой частоты выполнения. Утилита gcov не производит никаких временных данных и работает только с кодом, скомпилированным с помощью пакета GCC. В руководстве утверждается, что оно несовместимо с каким-либо другим механизмом профилирования или тестового покрытия.[3] но он работает с llvm -сгенерированные файлы тоже.
Описание
gcov производит анализ тестового покрытия специально оснащенного программа. Варианты -fprofile-arcs -ftest-охват
следует использовать для компиляции программы для анализа покрытия (первый вариант для записи статистики ветвлений, второй для сохранения счетчика выполненных строк); -fprofile-arcs
также следует использовать для связывания программы.[2] После запуска такая программа создаст несколько файлов с расширениями (суффиксами) «.bb», «.bbg» и «.da», которые можно будет проанализировать с помощью gcov. Он принимает исходные файлы в качестве аргументов командной строки и создает аннотированный список источников. Каждая строка исходного кода имеет префикс, указывающий количество раз, когда она была выполнена; строки, которые не были выполнены, имеют префикс "#####".[2]
gcov создает файл журнала с именем sourcefile.gcov который указывает, сколько раз каждая строка исходного файла sourcefile.c выполнил. Этот аннотированный исходный файл можно использовать с гпроф, еще один инструмент профилирования для извлечения информации о времени программы.
Пример
Следующая программа, написанная на Язык программирования C, петли над целыми числами от 1 до 9 и проверяет их делимость с помощью оператора модуля (%).
#включают <stdio.h>intглавный (пустота){ int я; за (я = 1; я < 10; я++) { если (я % 3 == 0) printf ("% d делится на 3 п", я); если (я % 11 == 0) printf ("% d делится на 11 п", я); } возвращаться 0;}
Чтобы включить тестирование покрытия, программа должна быть скомпилирована со следующими параметрами:
$ gcc -Wall -fprofile-arcs -ftest-охват cov.c
где cov.c - имя файла программы. Это создает инструментальную исполняемый файл который содержит дополнительные инструкции, которые записывают, сколько раз выполняется каждая строка программы. Опция -ftest-охват добавляет инструкции для подсчета количества выполнений отдельных строк, а -fprofile-arcs включает инструментальный код для каждой ветви программы. Инструментарий ветвления записывает, как часто используются разные пути с помощью операторов if и других условных выражений. В исполняемый файл затем необходимо запустить для создания данных покрытия. Данные из цикла записываются в несколько файлов с расширениями «.bb», «.bbg» и «.da» соответственно в текущем каталог. Эти данные можно проанализировать с помощью команды gcov и имени исходного файла:
$ gcov cov.c 88,89% из 9 строк исходного кода выполнено в файле cov.cСоздание cov.c.gcov
В gcov команда создает аннотированную версию оригинала исходный файл с расширением файла «.gcov», содержащим подсчет количества раз, когда каждая строка была выполнена:
#включают <stdio.h> int главный (пустота) { 1 int я; 10 за (я = 1; я < 10; я++) { 9 если (я % 3 == 0) 3 printf ("% d делится на 3 п", я); 9 если (я % 11 == 0)###### printf ("% d делится на 11 n", i); 9 } 1 возвращаться 0; 1 }
Количество строк можно увидеть в первом столбце вывода. Строки, которые не были выполнены, помечаются хешами «######».
Параметры командной строки
Эта секция может содержать чрезмерное количество сложных деталей, которые могут заинтересовать только определенную аудиторию.Октябрь 2020) (Узнайте, как и когда удалить этот шаблон сообщения) ( |
Утилита командной строки Gcov поддерживает следующие параметры при создании файлов с аннотациями из данных профиля:[4][5]
- -час (--помощь): Отобразить справку по использованию gcov (в стандартном выводе) и выйти без дальнейшей обработки.
- -v (--версия): Отобразить номер версии gcov (в стандартном выводе) и выйти без дальнейшей обработки.
- -а (--all-блоки): Записать индивидуальный счетчик выполнения для каждого базового блока. Обычно gcov выводит счетчик выполнения только для основных блоков строки. С помощью этой опции вы можете определить, не выполняются ли блоки в одной строке.
- -b (- ветвь-вероятности): Записывать частоты ветвлений в выходной файл и записывать сводную информацию ветвлений в стандартный выходной файл. Эта опция позволяет вам видеть, как часто выполнялась каждая ветвь в вашей программе. Безусловные переходы не будут отображаться, если не задана опция -u.
- -c (- количество филиалов): Запишите частоту ветвей как количество взятых ветвей, а не процент взятых ветвей.
- -n (--no-output): Не создавайте выходной файл gcov.
- -l (--long-file-names): Создайте длинные имена для включаемых исходных файлов. Например, если файл заголовка x.h содержит код и был включен в файл a.c, то запуск gcov для файла a.c приведет к созданию выходного файла с именем a.c ## x.h.gcov вместо x.h.gcov. Это может быть полезно, если x.h включен в несколько исходных файлов и вы хотите увидеть отдельные вклады. Если вы используете опцию `-p ', имена включаемых и включаемых файлов будут полными путями.
- -п (--preserve-paths): Сохранить полную информацию о пути в именах созданных файлов .gcov. Без этой опции используется только компонент имени файла. С этой опцией используются все каталоги с символами `/ ', переведенными в символы` #',. компоненты каталога удалены и невозможно удалить .. компоненты переименованы в `^ '. Это полезно, если исходные файлы находятся в нескольких разных каталогах.
- -р (- только относительный): Выводить информацию только об исходных файлах с относительным путем (после исключения префикса источника). Абсолютные пути обычно представляют собой файлы системных заголовков, и описание любых встроенных функций в них обычно неинтересно.
- -f (--функции-резюме): Вывод сводки для каждой функции в дополнение к сводке на уровне файла.
- -o каталог | файл (--object-directory каталог или же --object-file файл): Укажите либо каталог, содержащий файлы данных gcov, либо путь к объекту. С помощью этой опции выполняется поиск файлов данных .gcno и .gcda. Если каталог указан, файлы данных находятся в этом каталоге и названы по имени входного файла без его расширения. Если здесь указан файл, файлы данных будут названы в честь этого файла без его расширения.
- -s каталог (--source-prefix каталог): Префикс для имен исходных файлов, который необходимо удалить при создании файлов выходного покрытия. Этот параметр полезен при построении в отдельном каталоге, и путь к исходному каталогу не требуется при определении имен выходных файлов. Обратите внимание, что это определение префикса применяется до определения, является ли исходный файл абсолютным.
- -u (--unconditional-ветви): Если указаны вероятности переходов, включить в них вероятности безусловных переходов. Безусловные переходы обычно не интересны.
- -d (--display-progress): Отображение прогресса на стандартном выводе.
Сводные данные о покрытии
Львов это графический интерфейс для gcov. Он собирает данные gcov для нескольких исходных файлов и создает HTML страницы, содержащие исходный код, аннотированный информацией о покрытии. Он также добавляет обзорные страницы для удобной навигации по файловой структуре. Lcov поддерживает измерение покрытия операторов, функций и ветвей.[6] Также есть Версия для Windows.
Gcovr предоставляет утилиту для управления использованием gcov и создания итоговых результатов покрытия кода. Эта команда основана на пакете Python extension.py, который предоставляет аналогичную утилиту в Python. Gcovr создает компактные, удобочитаемые сводные отчеты, машиночитаемые отчеты XML или графическое резюме в формате HTML. XML-отчеты, созданные gcovr, могут использоваться Дженкинс для предоставления графических обзоров покрытия кода. Gcovr поддерживает измерение покрытия операторов и филиалов[7]
SCov - это утилита, обрабатывающая промежуточный текстовый формат, созданный gcov (с использованием gcov -i), для создания отчетов о покрытии кода. Эти отчеты могут быть простыми текстовыми отчетами или HTML страницы с более подробными отчетами.[8]
Смотрите также
- Тцов - инструмент покрытия кода для Solaris, входящий в пакет Sun Studio
Рекомендации
- ^ «Как работает GCOV - инструментальная часть GCC» (PDF). Архивировано из оригинал (PDF) 9 апреля 2014 г.. Получено 12 февраля, 2012. Цитировать журнал требует
| журнал =
(помощь) - ^ а б c Брайан Дж. Гоф. Введение в GCC - для компиляторов GNU gcc и g ++ - тестирование покрытия с помощью gcov. Получено 12 февраля, 2012.
- ^ "страница руководства gcov". Получено 12 февраля, 2012.
- ^ gnu.org. "Параметры командной строки Gcov". Получено 11 февраля, 2012.
- ^ команды linux. "Параметры командной строки Gcov". Архивировано из оригинал на 2013-01-08. Получено 12 февраля, 2012.
- ^ "Львов".
- ^ "Гцовр".
- ^ «СЦов».