博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
学会用Clang来进行内存泄露分析
阅读量:4605 次
发布时间:2019-06-09

本文共 941 字,大约阅读时间需要 3 分钟。

    最近项目出现了内存泄露的问题,对于PC x86平台来说,一点点的内存泄露往往不会出错,很难进行debug调试。这个时候我们可以用到苹果给我们带来的神器--Clang编译器来进行内存泄露分析检测,开关打开之后,生成出来的二进制文件对内存泄露的敏感程度非常高,只要有内存泄露基本就会立马停止并进行报错。

    由于项目是用CMake进行组织,因此使用CMake的方法来进行开关的打开,首先要让CC和CXX都变成Clang和Clang++(注意:在Clang下有时候会对inline函数报错,需要将inline去掉)。在build目录中输入

CC="clang" CXX="clang++" cmake ../ -DCMAKE_CXX_FLAGS="-fsanitize=address" -DCMAKE_BUILD_TYPE=Debug

其中的-DCMAKE_CXX_FLAGS="-fsanitize=address"就是打开这项内存泄露的检查开关(对于CMake来说,命令行的赋值对于CMAKE_CXX_FLAGS来说是真的在处理脚本之前做为保留,也就是说在进入CMakeLists.txt进行处理里面的flags的时候,此时你的CMAKE_CXX_FLAGS已经包含了-fsanitize=address了,你只需要在后期脚本的处理过程中注意每当set falgs的时候要set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${your_own_flags}"),维护好脚本中flags的追加过程就没有问题了),然后对项目进行编译,之后编译出来的文件你就可以正常运行,运行程序之后,它会去调用你path下Clang文件夹bin中的llvm-symbolizer进行符号读取,一有内存泄露它就会停止报错。然后传给终端的信息里面详细介绍了在内存的申请是在哪个线程哪个函数开始的,内存的删除是在哪个线程哪个函数进行的,内存最后的读取(即野指针的重复滥用最终导致内存泄露)是在哪个线程哪个函数进行的,这对于多线程的开发自然又是如虎添翼,希望你会和我一样喜欢这款工具。

   

转载于:https://www.cnblogs.com/rickyk/p/3794523.html

你可能感兴趣的文章
[luogu3203 HNOI2010] 弹飞绵羊 (分块)
查看>>
-Dmaven.multiModuleProjectDirectory system propery is not set.
查看>>
Python2 unichr() 函数
查看>>
Python 字典 copy()方法
查看>>
Minimum Path Sum
查看>>
Remove Duplicates from Sorted Array II
查看>>
常量指针和指针常量巧妙记忆方法[转]
查看>>
python-haproxy作业讲解视频总结
查看>>
mui搜索框 搜索点击事件
查看>>
select2 下拉搜索控件
查看>>
WebAPI常见的鉴权方法,及其适用范围
查看>>
08. 删除重复&海量数据
查看>>
重新想象 Windows 8 Store Apps (71) - 其它: C# 调用 C++
查看>>
发布mvc遇到的HTTP错误 403.14-Forbidden解决办法
查看>>
记录一些好用的工具
查看>>
超链接样式设置(去下划线)(转)
查看>>
2016012003+陈琦+散列函数的应用及其安全性
查看>>
Android 状态栏通知Notification、NotificationManager详解
查看>>
UIApplicationDelegate协议
查看>>
Jmeter测试dubbo接口填坑
查看>>