admin管理员组文章数量:1567026
valgrind这款免费软件时linux上一款强大的调试和分析工具。其中一个较为厉害的功能就是内存泄漏分析和定位。
使用valgrind分析内存泄漏时需要请注意:
1、尽可能的让程序处于全符号和未优化状态运行。这样的话,valgrind甚至可以定位到导致内存泄露的那一行。最不济也可以定位到泄露位置的前后几行,很方便的可以分析泄露位置。
2、让程序正常退出。如果是一直运行的服务的话,可以捕获ctrl+c或者ctrl+v,然后再事件响应回调中让服务正常退出。这样即可极大减小valgrind的误报率。
使用如下命令开启valgrind:
valgrind --leak-check=full --show-leak-kinds=all --log-file=vallog ./server.out(其中server.out是要检测的程序)
然后疯狂压测,让泄露发生,再觉得差不多时,让程序正常退出。这时会在程序运行目录生成一个分析文件vallog。vallog是文本内容,可以直接打开。最后几行会和下面类似:
==31438== LEAK SUMMARY:
==31438== definitely lost: 0 bytes in 0 blocks
==31438== indirectly lost: 0 bytes in 0 blocks
==31438== possibly lost: 0 bytes in 0 blocks
==31438== still reachable: 72,704 bytes in 1 blocks
==31438== suppressed: 0 bytes in 0 blocks
==31438==
==31438== For counts of detected and suppressed errors, rerun with: -v
==31438== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0)
definitely lost 表示一定泄露的内存,其他的可以不管,如果你只是查找内存泄漏。然后vallog内 查找单词definitely ,就可以定位到哪些地方发生了泄露。
have a fun!
版权声明:本文标题:分析linux程序的内存泄露的利器 valgrind 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://www.elefans.com/dianzi/1725886748a1047100.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论