谷歌开源项目 Sanitizer :
包含了 ASAN、LSAN、MSAN、TSAN 等内存、线程错误的检测工具
ASAN 全称 AddressSanitizer: 内存错误检测工具, GCC高版本已自带
相比于Valgrind,ASAN除了能检查到堆内存的越界访问和悬空指针的访问,
还能检测到栈和全局对象的越界访问,性能快一个数量级。
在编译命令中添加-fsanitize=address启用,缓冲区溢出或对悬空指针的非法访问;
其中,选项 -fsanitize-recover=address 支持内存出错之后程序继续运行,
但需要叠加设置ASAN_OPTIONS=halt_on_error=0 才会生效;
若未设置此选项,则内存出错即报错退出;
另外: -g 表示日志中添加行号
参考:https://www.cnblogs.com/callmesblog/p/17199328.html
g++ -fsanitize=address -g test_leak.cc && ./a.out
#在CMakeLists.txt文件中,添加如下即可:
set(CMAKE_CXX_FLAGS