asan(AddressSanitizer)内存诊断(越界,非法访问等)工具使用---一款比valgrind更好用的工具

   日期:2020-11-04     浏览:561    评论:0    
核心提示:操作系统:centos8gcc:8.3.1 asan是gcc原生的内存诊断工具,可以诊断内存越界,非法访问,内存泄漏,内存double free等常见内存问题,并且效率比valgrind高好几倍,可以克服valgrind的一些问题,比如占用内存高的问题,是一款比valgrind更好用的内存问题分析工具!1.准备工作: 1.在编译环境上安装asan的开发库 yum install libasan.x86_64 2.在运...

操作系统:centos8 

gcc:8.3.1

 

        asan是gcc原生的内存诊断工具,可以诊断内存越界,非法访问,内存泄漏,内存double free等常见内存问题,并且效率比valgrind高好几倍,可以克服valgrind的一些问题,比如占用内存高的问题,是一款比valgrind更好用的内存问题分析工具!

 

1.准备工作:

       1.在编译环境上安装asan的开发库

          yum install libasan.x86_64

      2.在运行环境上安装asan的开发库,如果运行环境无法联网,可以先用yum download下来,再放到运行环境上安装

 

2.编译

CFLAGS+=-fsanitize=address -fno-omit-frame-pointer -fsanitize-recover=address     //需要与环境变量ASAN_OPTIONS=halt_on_error=0配合使用

SYSLIB+=-lasan               //如果找不到库,还需要加上-L加上库的路径

 

3.运行

export ASAN_OPTIONS=halt_on_error=0 //使进程检测出内存错误的时候别退出

export ASAN_OPTIONS=alloc_dealloc_mismatch=0 //不检测内存不匹配的情况,例如 new [] 与delete point 不匹配

asan的选项很多,可以根据需要设置ASAN_OPTIONS的选项,其他选项可以自行百度

 

export LD_PRELOAD=/usr/lib64/libasan.so.5.0.0 //预加载运行库,替换系统库libc中内存分配函数

LD_PRELOAD是Linux系统的一个环境变量,它可以影响程序的运行时的链接(Runtime linker),它允许你定义在程序运行前优先加载的动态链接库,这个环境变量是必须的,因为libasan.so.5.0.0会替换掉libc中malloc和free函数的实现,所以需要将该库进行预加载。

至此,所有工作完成,直接运行所需要测试的程序即可,程序会打印出检测出来的内存问题。

 

      

 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服