简介

https://zhuanlan.zhihu.com/p/360135083

使用方式

添加编译选项

 -Lasan -fsanitize=address -fsanitize-recover=address -fno-omit-frame-pointer

编写代码文件,如添加test_asan.c

#include<stdio.h>
#include<stdlib.h>int main(){//未释放的内存,会产生内存泄漏int* arr = (int*)malloc(sizeof(int) * 10);return 0;
}

1.gcc添加方式

gcc -g test_asan.c -o t1 -Lasan -fsanitize=address -fsanitize-recover=address -fno-omit-frame-pointer

2.CMakeLists添加方式

cmake_minimum_required(VERSION 2.8)project(test C)
set(CMAKE_C_STANDARD 99)set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -g -Lasan -fsanitize=address -fsanitize-recover=address -fno-omit-frame-pointer")add_executable(t1 test_asan.c)

ps:一般需要添加-g,否则仅仅会输出错误,找不到对应函数与行号。
重新编译生成可执行文件
查找动态库位置

find /usr -name 'libasan.so'
#/usr里面没有也可以全局查找或自行安装
find / -name 'libasan.so'
#输出位置如下
/usr/local/lib64/libasan.so

添加动态库

export LD_PRELOAD=/usr/local/lib64/libasan.so

执行程序,可以看到内存泄漏问题并定位

./t1
=================================================================
==2154==ERROR: LeakSanitizer: detected memory leaksDirect leak of 40 byte(s) in 1 object(s) allocated from:#0 0xffff852eb67b in __interceptor_malloc ../../.././libsanitizer/asan/asan_malloc_linux.cc:62#1 0x400853 in main /home/lichangshi/ML2/my_test/test_ascan.c:5#2 0xffff850a1723 in __libc_start_main (/lib64/libc.so.6+0x21723)#3 0x40076b  (/home/lichangshi/ML2/my_test/t1+0x40076b)#4 0xffffe963f53c  (<unknown module>)

第二次编译之前需要清除添加的动态库

unset LD_PRELOAD

注意:
一定要在编译之后添加动态库位置,如果在编译前添加libasan.so动态库,编译阶段输出以下错误,CMake无法生成可执行文件。

    ===================================================================2644==ERROR: LeakSanitizer: detected memory leaksDirect leak of 112 byte(s) in 1 object(s) allocated from:#0 0xffffa2f3b82b in __interceptor_calloc ../../.././libsanitizer/asan/asan_malloc_linux.cc:70#1 0xf2748b in xcalloc ../.././libiberty/xmalloc.c:162#2 0xf2463b in htab_create_typed_alloc ../.././libiberty/hashtab.c:357#3 0xef0243 in linemap_init(line_maps*, unsigned int) ../.././libcpp/line-map.c:354#4 0x542aa3 in general_init ../.././gcc/toplev.c:1141#5 0x542aa3 in toplev::main(int, char**) ../.././gcc/toplev.c:2092#6 0x544823 in main ../.././gcc/main.c:39#7 0xffffa2ab1723 in __libc_start_main (/lib64/libc.so.6+0x21723)#8 0x544c8b  (/usr/local/libexec/gcc/aarch64-unknown-linux-gnu/7.3.0/cc1+0x544c8b)#9 0xfffff243f2e6  (<unknown module>)
...省略

上述错误显示的文件为linux中的代码文件,推测是cmake可能存在内存泄漏问题,或cmake的执行代码中的malloc被替换为Ascan中的申请方式可能无法正确执行。具体原因还请相关专业人士解答。

常见错误类型

1.内存泄漏(Memory leaks),即申请的内存未释放。

#include<stdio.h>
#include<stdlib.h>int main(){//未释放的内存,会产生内存泄漏int* arr = (int*)malloc(sizeof(int) * 10);return 0;
}
./t1
=================================================================
==2154==ERROR: LeakSanitizer: detected memory leaksDirect leak of 40 byte(s) in 1 object(s) allocated from:#0 0xffff852eb67b in __interceptor_malloc ../../.././libsanitizer/asan/asan_malloc_linux.cc:62#1 0x400853 in main /home/lichangshi/ML2/my_test/test_ascan.c:5#2 0xffff850a1723 in __libc_start_main (/lib64/libc.so.6+0x21723)#3 0x40076b  (/home/lichangshi/ML2/my_test/t1+0x40076b)#4 0xffffe963f53c  (<unknown module>)

2.栈溢出(Stack buffer overflow),函数中的变量,参数,引用,指针,返回地址等存储在栈中,若超出栈的容量会导致栈溢出,常见情形为递归过深或申请的数组过大。

void stack_buffer_overflow(){long long len = 1024*1024*1024;double a[len];for(int i = 0; i < len; i++){a[i] = -1.0;}return;
}int main(){stack_buffer_overflow();return 0;
}
ASAN:DEADLYSIGNAL
=================================================================
==10239==ERROR: AddressSanitizer: stack-overflow on address 0xfffde74c4500 (pc 0x000000400b0c bp 0xffffe74c4510 sp 0xfffde74c4500 T0)#0 0x400b0b in stack_buffer_overflow /home/lichangshi/ML2/my_test/test_asan.c:13#1 0x400b4f in main /home/lichangshi/ML2/my_test/test_asan.c:19#2 0xffff97301723 in __libc_start_main (/lib64/libc.so.6+0x21723)#3 0x40093b  (/home/lichangshi/ML2/my_test/build/test+0x40093b)SUMMARY: AddressSanitizer: stack-overflow /home/lichangshi/ML2/my_test/test_asan.c:13 in stack_buffer_overflow
==10239==ABORTINGSUMMARY: AddressSanitizer: stack-overflow (/home/lichangshi/ML2/my_test/build/test+0x400b0b) in stack_buffer_overflow
==10284==ABORTING

3.堆溢出(heap buffer overflow)。堆中存储动态申请内存,如malloc(), calloc(), new int[]等,常见情况为访问到申请内存之外的地址。

void heap_buffer_overflow(){int* a = (int*)malloc(sizeof(int)*10);a[11] = 1;return;
}int main(){heap_buffer_overflow();return 0;
}
=================================================================
==10349==ERROR: AddressSanitizer: heap-buffer-overflow on address 0xffffb4c00f7c at pc 0x000000400c44 bp 0xfffffbffb640 sp 0xfffffbffb658
WRITE of size 4 at 0xffffb4c00f7c thread T0#0 0x400c43 in heap_buffer_overflow /home/lichangshi/ML2/my_test/test_asan.c:20#1 0x400c67 in main /home/lichangshi/ML2/my_test/test_asan.c:25#2 0xffffb8091723 in __libc_start_main (/lib64/libc.so.6+0x21723)#3 0x4009cb  (/home/lichangshi/ML2/my_test/build/test+0x4009cb)0xffffb4c00f7c is located 4 bytes to the right of 40-byte region [0xffffb4c00f50,0xffffb4c00f78)
allocated by thread T0 here:#0 0xffffb838b67b in __interceptor_malloc ../../.././libsanitizer/asan/asan_malloc_linux.cc:62#1 0x400be7 in heap_buffer_overflow /home/lichangshi/ML2/my_test/test_asan.c:19#2 0x400c67 in main /home/lichangshi/ML2/my_test/test_asan.c:25#3 0xffffb8091723 in __libc_start_main (/lib64/libc.so.6+0x21723)#4 0x4009cb  (/home/lichangshi/ML2/my_test/build/test+0x4009cb)#5 0xfffffbfff53c  (<unknown module>)SUMMARY: AddressSanitizer: heap-buffer-overflow /home/lichangshi/ML2/my_test/test_asan.c:20 in heap_buffer_overflow
Shadow bytes around the buggy address:0x200ff6980190: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa0x200ff69801a0: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa0x200ff69801b0: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa0x200ff69801c0: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa0x200ff69801d0: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa
=>0x200ff69801e0: fa fa fa fa fa fa fa fa fa fa 00 00 00 00 00[fa]0x200ff69801f0: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa0x200ff6980200: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa0x200ff6980210: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa0x200ff6980220: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa0x200ff6980230: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa
Shadow byte legend (one shadow byte represents 8 application bytes):Addressable:           00Partially addressable: 01 02 03 04 05 06 07Heap left redzone:       faFreed heap region:       fdStack left redzone:      f1Stack mid redzone:       f2Stack right redzone:     f3Stack after return:      f5Stack use after scope:   f8Global redzone:          f9Global init order:       f6Poisoned by user:        f7Container overflow:      fcArray cookie:            acIntra object redzone:    bbASan internal:           feLeft alloca redzone:     caRight alloca redzone:    cb
==10349==ABORTING

4.全局溢出(Global buffer overflow)。
把超大静态数组/放到全局变量中或越界访问静态数组,不写了。
等等

参考链接

https://zhuanlan.zhihu.com/p/360135083
https://www.jianshu.com/p/9e85345e500b
栈溢出是什么:
https://zhuanlan.zhihu.com/p/73411916
堆溢出是什么:
https://eternalsakura13.com/2018/02/28/heap_exp1/

内存泄漏工具asan相关推荐

  1. java 内存泄漏 工具_Java剖析工具JProfiler入门使用教程:查找内存泄漏的方法

    JProfiler的内存视图会话提供了内存使用情况的动态更新视图以及分配点的信息视图.所有的视图都有几个聚集层并且能够显示现有存在的对象和作为垃圾回收的对象.本文主要介绍如何意识到内存泄漏以及查找内存 ...

  2. mtrace内存泄漏工具的使用方法

    原理: mtrace 工具的主要思路是在我们的调用内存分配和释放的函数中装载 "钩子(hook)" 函数,通过 "钩子(hook)" 函数打印的日志来帮助我们分 ...

  3. malloc钩子和内存泄漏工具mtrace、Valgrind

    一:malloc钩子函数 static void* (* old_malloc_hook) (size_t,const void *); static void (* old_free_hook)(v ...

  4. 内存泄漏工具VLD安装及使用

    1.初始VLD VLD:Visual Leak Detector,可视化泄漏检测. 2.安装VLD(适用于vs2010~vs2015) 其它版本请参考其他文章进行手动配置. 软件下载地址:https: ...

  5. Linux/Android之perf追内存泄漏工具(api级别)

    一.安装 # sudo apt install linux-tools-common # sudo apt install linux-tools-5.4.0-59-generic # perf to ...

  6. Linux/Android之perf追内存泄漏工具(api级别)(一百)

    一.安装及用法 # sudo apt install linux-tools-common # sudo apt install linux-tools-5.4.0-59-generic # perf ...

  7. android 监测内存泄漏工具,LeakCanary:Android内存泄漏检测工具

    LeakCanary A memory leak detection library for Android and Java. "A small leak will sink a grea ...

  8. 内存泄漏检测工具asan

    1.使用内存泄漏工具asan需要添加编译选项 -Lasan -fsanitize=address -fsanitize-recover=address -fno-omit-frame-pointer ...

  9. 常用的内存泄漏检查工具

    以下是一些常用的内存泄漏检查工具: 1. Valgrind:Valgrind是一种开源的内存调试和性能分析工具,可以检测内存泄漏.使用未初始化的内存.使用已释放的内存等问题. 2. AddressSa ...

  10. 内存泄漏查找工具----valgrind简介与使用

    目录 1 valgrind简介 2 常用参数 3 使用示例 用了一下asan,感觉比valgrid好用,以后用asan,asan的使用方法内存错误分析工具----asan(AddressSanitiz ...

最新文章

  1. GitLab 上市,市值高达 149 亿美元!GitHub 的头号劲敌来了
  2. R语言使用ggradar包可视化基本雷达图(radar chart、蜘蛛图spider plot)、可视化单个数据对象的雷达图
  3. nginx gzip配置
  4. python基础知识选择题-python基础知识练习题(二)
  5. 能否把指针变量本身传递给一个函数?
  6. java 自定义 钩子_使用现有钩子的函数不能使用自定义do_action钩子
  7. 训练日志 2019.3.10
  8. linux 内核 md5 算法_Linux内核中的数据结构和算法
  9. apache、node.js、nginx、tomcat的关系
  10. WSUS补丁更新相关命令及参数
  11. Spring-扫描/jar/读取Classpath下的文件资源
  12. UNIX高手的20个习惯
  13. STL sort的危险之处
  14. java doctitle_Java ActionItem.setDocTitle方法代码示例
  15. 本机连接虚拟机mysql,使用本机Navicat连接CentOS虚拟机的MySQL
  16. 透明png图片和素材免费下载网站
  17. 股票数据库接口是什么意思?
  18. pgsql timestamp without time zone > character varying解决方案
  19. 冯东阳:解读纯文本链接到底算不算外链
  20. 恶意软件的历史和应对措施

热门文章

  1. html如何添加qq聊天框
  2. ONLYOFFICE权限开发之二
  3. CentOS Mac 安装zsh,使用oh-my-zsh
  4. 5个适合提升自己的自学网站,每一个都很强大, 适合职场人自我提升的学习网站,利用起来,离加薪更近一步
  5. Java 使用 POI 3.17根据Word 模板替换、操作书签
  6. 火狐浏览器Firefox 提示错误代码:SSL_ERROR_UNSUPPORTED_VERSION的正确解决方法
  7. 菜鸟网络今日发布超级机器人旗舰仓
  8. Android studio最新版2021安装教程超详细。
  9. android 常用机型尺寸_安卓手机屏幕多大合适?6.4英寸是“黄金尺寸”吗?
  10. 浅谈Python爬虫(八)【有道词典翻译API】