首页 > 后端开发 > C++ > 正文

如何使用 Valgrind 或 AddressSanitizer 查找 C++ 中的内存泄漏?

PHPz
发布: 2024-05-31 08:00:02
原创
1186人浏览过

要查找 c++++ 中的内存泄漏,可以利用 valgrind 和 addresssanitizer。valgrind 动态检测泄漏,显示地址、大小和调用栈。addresssanitizer 是一个 clang 编译器插件,检测内存错误和泄漏。要启用 asan 泄漏检查,请在编译时使用 --leak-check=full 选项,该选项将在程序运行后报告泄漏。

如何使用 Valgrind 或 AddressSanitizer 查找 C++ 中的内存泄漏?

如何使用 Valgrind 或 AddressSanitizer 查找 C++ 中的内存泄漏

引言
内存泄漏是 C++ 等语言中的一个常见问题。为了检测和解决这些泄漏,可以使用像 Valgrind 和 AddressSanitizer 这样的工具。

使用 Valgrind 查找内存泄漏
Valgrind 是一个动态内存调试工具,可以检测内存泄漏。要使用 Valgrind:

立即学习C++免费学习笔记(深入)”;

valgrind ./my_program
登录后复制

Valgrind 将运行程序并报告任何检测到的内存泄漏。输出将显示泄漏的地址、大小和调用栈。

示例
以下 C++ 代码示例演示了 Valgrind 如何检测内存泄漏:

int* ptr = new int[10];
// ...
// 忘记释放 ptr
登录后复制

运行此代码并使用 Valgrind,将输出以下结果:

Trae国内版
Trae国内版

国内首款AI原生IDE,专为中国开发者打造

Trae国内版 815
查看详情 Trae国内版
==8445== LeakSanitizer: detected memory leaks
==8445== Direct leak of 40 bytes in 1 object(s) allocated from:
    #0 0x49f2c0 in default_new_allocator_000000157013e0000000 ::operator() () (_libunwind.dylib:0x103d8e000)
    #1 0x41626f in create_array () in /tmp/a.out:10
    #2 0x415b2d in main () in /tmp/a.out:15

SUMMARY:
==8445== LEAK SUMMARY:
==8445==    definitely lost: 40 bytes in 1 object(s)
登录后复制

输出显示了泄漏了 40 字节,并在地址 0x49f2c0 处分配。

使用 AddressSanitizer 查找内存泄漏
AddressSanitizer (ASan) 是一个 Clang 编译器插件,可以检测内存错误,包括内存泄漏。要使用 ASan:

clang++ -fsanitize=address ...
登录后复制

ASan 将检测内存访问错误,并在发生错误时生成崩溃报告。要检查内存泄漏,请运行程序两次:

./my_program # 第一次运行
./my_program --leak-check=full # 第二次运行,启用泄漏检查
登录后复制

第二次运行将报告任何检测到的内存泄漏。

示例
以下 C++ 代码示例演示了 AddressSanitizer 如何检测内存泄漏:

int* ptr = new int[10];
// ...
// 忘记释放 ptr
登录后复制

编译并运行此代码,启用 ASan,将输出以下结果:

==28847== ERROR: AddressSanitizer: detected memory leaks
    SUMMARY:
    ==28847== LeakSanitizer: 40 byte(s) leaked in 1 allocation(s).
    ==28847==
    0x7fdd1b000010  40 bytes in 1 block
      ==28847== LeakSanitizer:
      ==28847==  Direct leak of 40 bytes in 1 object(s) allocated from:
      ==28847==    #0 0x7fdd17a346c0 in __sanitizer::Allocator<std::__detail::__shared_count>::allocate(unsigned long) (_sanitizer.h:1195)
      ==28847==    #1 0x7fdd184d0f90 in void* std::__detail::__shared_count<unsigned int>::allocate() (_shared_count.h:128)
      ==28847==    #2 0x7fdd182de485 in void* std::__shared_ptr<int>::__clone() (_shared_ptr.h:256)
      ==28847==    #3 0x48b935 in create_array() (/tmp/a.out:10)
      ==28847==    #4 0x48b884 in main (/tmp/a.out:15)
登录后复制

输出显示了泄漏了 40 字节,并在地址 0x7fdd1b000010 处分配。

以上就是如何使用 Valgrind 或 AddressSanitizer 查找 C++ 中的内存泄漏?的详细内容,更多请关注php中文网其它相关文章!

相关标签:
c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号