欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 运维知识 > linux >内容正文

linux

【调试】Linux下超强内存检测工具Valgrind

发布时间:2023/12/13 linux 48 豆豆
生活随笔 收集整理的这篇文章主要介绍了 【调试】Linux下超强内存检测工具Valgrind 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

【调试】Linux下超强内存检测工具Valgrind

 

内容简介


  • Valgrind是什么?
  • Valgrind的使用
  • Valgrind详细教程
  • 1. Valgrind是什么?


    Valgrind是一套Linux下,开放源代码(GPL
    V2)的仿真调试工具的集合。Valgrind由内核(core)以及基于内核的其他调试工具组成。

    内核类似于一个框架(framework),它模拟了一个CPU环境,并提供服务给其他工具;而其他工具则类似于插件 (plug-in),利用内核提供的服务完成各种特定的内存调试任务。

    Valgrind的体系结构如下图所示:

    Valgrind包括如下一些工具:

    • Memcheck:这是valgrind应用最广泛的工具,一个重量级的内存检查器,能够发现开发中绝大多数内存错误使用情况,比如:使用未初始化的内存,使用已经释放了的内存,内存访问越界等。

    • Callgrind:它主要用来检查程序中函数调用过程中出现的问题。

    • Cachegrind:它主要用来检查程序中缓存使用出现的问题。

    • Helgrind:它主要用来检查多线程程序中出现的竞争问题。

    • Massif:它主要用来检查程序中堆栈使用中出现的问题。

    • Extension:可以利用core提供的功能,自己编写特定的内存调试工具。

    2. Valgrind的使用

    为了使valgrind发现的错误更精确,如能够定位到源代码行,建议在编译时加上-g参数,编译优化选项请选择O0,虽然这会降低程序的执行效率。

    这里用到的示例程序文件名为:test.c,选用的编译器为gcc。

    生成可执行程序

    gcc -g -O0 test.c -o test

    生成可执行程序test之后,如何使用Valgrind来生成内存的记录文件呢?一般这样使用:

    valgrind --leak-check=full --log-file=test_valgrind.log --num-callers=30 ./test
    • --log-file 后面的test_valgrind.log是指定生成的日志文件名称。

    • --num-callers 后面的60是生成的每个错误记录的追踪行数。30是随便设定的,如果没指定,默认是12行貌似(有可能有的追踪行就没显示)。

    • --leak-check=full 表示开启详细的内存泄露检测器。

    3. Valgrind详细教程

    详细教程请看这篇文章:
    应用Valgrind发现Linux程序的内存问题


    我是谢恩铭,在法国巴黎奋斗的嵌入式软件工程师。
    目前工作是Android嵌入式和app开发。
    热爱生活,喜欢游泳,略懂烹饪。

     Linux探

    转载于:https://www.cnblogs.com/zhehan54/p/6362306.html

    总结

    以上是生活随笔为你收集整理的【调试】Linux下超强内存检测工具Valgrind的全部内容,希望文章能够帮你解决所遇到的问题。

    如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。