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