LeakSanitizer¶
简介¶
LeakSanitizer 是一个运行时内存泄漏检测器。它可以与 地址消毒器 结合使用,以同时进行内存错误和泄漏检测,也可以单独使用。LSan 在进程结束之前几乎不会增加性能开销,在该阶段会额外进行泄漏检测阶段。
用法¶
地址消毒器: 集成 LeakSanitizer 并默认在支持的平台上启用它。
$ cat memory-leak.c
#include <stdlib.h>
void *p;
int main() {
p = malloc(7);
p = 0; // The memory is leaked here.
return 0;
}
% clang -fsanitize=address -g memory-leak.c ; ASAN_OPTIONS=detect_leaks=1 ./a.out
==23646==ERROR: LeakSanitizer: detected memory leaks
Direct leak of 7 byte(s) in 1 object(s) allocated from:
#0 0x4af01b in __interceptor_malloc /projects/compiler-rt/lib/asan/asan_malloc_linux.cc:52:3
#1 0x4da26a in main memory-leak.c:4:7
#2 0x7f076fd9cec4 in __libc_start_main libc-start.c:287
SUMMARY: AddressSanitizer: 7 byte(s) leaked in 1 allocation(s).
要以独立模式使用 LeakSanitizer,请使用 -fsanitize=leak
标志链接您的程序。确保使用 clang
(而不是 ld
)进行链接步骤,以便它将适当的 LeakSanitizer 运行时库链接到最终的可执行文件。
安全注意事项¶
LeakSanitizer 是一种错误检测工具,其运行时不适合链接到生产可执行文件。虽然它可能对测试有用,但 LeakSanitizer 的运行时并非在考虑安全敏感约束的情况下开发的,可能会危及生成的可执行文件的安全性。
支持平台¶
Android aarch64/i386/x86_64
Fuchsia aarch64/x86_64
Linux arm/aarch64/mips64/ppc64/ppc64le/riscv64/s390x/i386/x86_64
macOS aarch64/i386/x86_64
NetBSD i386/x86_64
更多信息¶
https://github.com/google/sanitizers/wiki/AddressSanitizerLeakSanitizer