Difference between revisions of "Profiling/ru"

From Free Pascal wiki
Jump to navigationJump to search
(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 (англ):

Heaptrc index

Переменная среда

Использование

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