Difference between revisions of "Profiling/ru"
(sync with English version, formatting, better language) |
(added memcheck section) |
||
Line 36: | Line 36: | ||
[http://www.freepascal.org/docs-html/rtl/heaptrc/usage.html Использование] | [http://www.freepascal.org/docs-html/rtl/heaptrc/usage.html Использование] | ||
+ | |||
+ | === Valgrind Memcheck === | ||
+ | |||
+ | Модуль heaptrc может не обнаружить некоторые утечки. В состав valgrind входит утилита memcheck, которая осуществляет гораздо больше проверок и умеет обнаруживать больше разновидностей ошибок. Недостатком является низкая скорость работы, поэтому использовать memcheck рекомендуется только в случаях, когда heaptrc не помогает. Пример использования: | ||
+ | |||
+ | valgrind --tool=memcheck --leak-check=summary --log-file=log.txt ./project1 | ||
+ | |||
+ | Файл log.txt почти никогда не бывает пустым, т.к. проверяется не только собственно программа, но и все используемые ей библиотеки. Качество многих библиотек часто оставляет желать лучшего. | ||
+ | |||
+ | Еще больше информации можно получить с помощью команды: | ||
+ | |||
+ | valgrind --tool=memcheck --leak-check=full --log-file=log.txt --show-reachable=yes --num-callers=50 ./project1 |
Revision as of 17:38, 19 December 2009
│
English (en) │
français (fr) │
русский (ru) │
Профилирование памяти
Heaptrc, LineInfo
Для обнаружения утечек памяти просто соберите программу с ключом "-gh". Это равнозначно добавлению модуля heaptrc первым в список используемых модулей программы. Модуль встраивается в менеджер памяти fpc и производит различные проверки.
При использовании heaptrc совместно с ключом -gl (добавление отладочной информации о строках), можно получить информацию о том, какой код вызывал утечку.
Поведение модуля heaptrc можно контролировать с помощью переменной окружения HEAPTRC, которая может содержать следующие значения:
keepreleased
: освобождаемая память не выделяется повторно, а попытки записи в нее отслеживаются.disabled
: отключить трассировку. Позволяет отключить проверку памяти в скомпилированной (с -gh) программе.nohalt
: По умолчанию heaptrc останавливает программу при первой же найденной ошибке. Если это значение присутствует, то выполнение программы продолжится, несмотря на ошибку.haltonnotreleased
: По умолчанию heaptrc печатает информацию обо всех "утечках", что может занимать много времени. Добавив этот параметр, можно ограничить печать только информацией о первой найденной утечке.log=<имя_файла>
: задать имя файла, куда будет выводиться информация об утечках. Если файл не указан, используется стандартный поток вывода (stdout), при этом возможны ошибки в графических приложениях Windows.
например:
HEAPTRC=log=c:\helloworld.trc
Модуль heaptrc можно использовать явно. Однако, он должен быть также первым модулем, подключаемым программой (файлом проекта в Lazarus-е). Если heaptrc используется явно, то вы уже не сможете скомпилировать программу с -gh, однако, использование -gl необходимо для получения информации о месте утечки.
Внимание: heaptrc конфликтует с модулем cmem. При необходимости отладки внешних библиотек следует использовать Valgrind.
Дополнительная информация о модуле heaptrc в документации на RTL (англ):
Valgrind Memcheck
Модуль heaptrc может не обнаружить некоторые утечки. В состав valgrind входит утилита memcheck, которая осуществляет гораздо больше проверок и умеет обнаруживать больше разновидностей ошибок. Недостатком является низкая скорость работы, поэтому использовать memcheck рекомендуется только в случаях, когда heaptrc не помогает. Пример использования:
valgrind --tool=memcheck --leak-check=summary --log-file=log.txt ./project1
Файл log.txt почти никогда не бывает пустым, т.к. проверяется не только собственно программа, но и все используемые ей библиотеки. Качество многих библиотек часто оставляет желать лучшего.
Еще больше информации можно получить с помощью команды:
valgrind --tool=memcheck --leak-check=full --log-file=log.txt --show-reachable=yes --num-callers=50 ./project1