1. AddressSanitizer+cmake(Linux)
编译指令:
CXXFLAGS通常需要加上
-fsanitize=address
-fno-omit-frame-pointer #打印函数调用路径
-fsanitize-recover=address #AddressSanitizer遇到错误时能够继续
-fsanitize=address
-fno-omit-frame-pointer
-fsanitize-recover=address
### 2. 运行时动态链接
设置环境变量,如设置AddressSanitizer遇到错误时继续运行
export ASAN_OPTIONS="halt_on_error=0:abort_on_error=0"
链接ASAN库
LD_PRELOAD=xxxxx/libasan.so ./out
sun@sun:~/nolo/asan_test$ g++ asan_test.cpp -o main -fsanitize=leak
sun@sun:~/nolo/asan_test$ ls
asan_test.cpp main
sun@sun:~/nolo/asan_test$ ./main
=================================================================
==184528==ERROR: LeakSanitizer: detected memory leaks
Direct leak of 40 byte(s) in 1 object(s) allocated from:
#0 0x7fa1c10cc501 in operator new[](unsigned long) ../../../../src/libsanitizer/lsan/lsan_interceptors.cpp:231
#1 0x5595b681319e in main (/home/sun/nolo/asan_test/main+0x119e)
#2 0x7fa1c0ba50b2 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x270b2)
SUMMARY: LeakSanitizer: 40 byte(s) leaked in 1 allocation(s).
sun@sun:~/nolo/asan_test$ cat asan_test.cpp
#include <iostream>
int main()
{
int* p = new int[10];
p = NULL;
return 0;
}
3. 安装
AddressSanitizer(地址杀菌剂,简称 ASan) 是谷歌出品的内存检查工具,比 Valgrind 更高效。其由两部组成:
编译器 instrumentation 模块
提供malloc()/free()替代项的运行时库
gcc 4.8 开始,AddressSanitizer 成为 gcc 的一部分,但不支持符号信息,无法显示出问题的函数和行数。从 4.9 开始,gcc 支持 AddressSanitizer 的所有功能。
Ubuntu 一般不用安装,CentOS 一般需要安装。
如果使用 AddressSanitizer 时报错:
/usr/bin/ld: cannot find /usr/lib64/libasan.so.0.0.0
则需要先安装。Ubuntu 安装命令:
sudo apt-get install libasan0
CentOS 安装命令:
sudo yum install libasan
使用
在用 gcc 编译程序时,指定 -fsanitize=address 选项即可自动调用 AddressSanitizer。运行程序时,就可以看到相关信息。
通过 -g 选项,可以看到报错的函数和行号。
3. 参考
博客园:https://www.cnblogs.com/kika/p/10851494.html
Github 地址:https://github.com/google/sanitizers
Wiki 地址:https://github.com/google/sanitizers/wiki/AddressSanitizer
基本使用:https://blog.csdn.net/c_lazy/article/details/80009627
输出信息的详细解释:https://www.jianshu.com/p/3a2df9b7c353