#内存泄露# #valgrind# valgrind使用

https://blog.csdn.net/xiaoting451292510/article/details/104943986

#内存泄露# #valgrind#valgrind-3.15.0 编译&&交叉编译

https://blog.csdn.net/xiaoting451292510/article/details/104931772

Valgrind 概述

体系结构

Valgrind是一套Linux下,开放源代码(GPL V2)的仿真调试工具的集合,官方地址:http://valgrind.org/。Valgrind由内核(core)以及基于内核的其他调试工具组成。内核类似于一个框架(framework),它模拟了一个CPU环境,并提供服务给其他工具;而其他工具则类似于插件 (plug-in),利用内核提供的服务完成各种特定的内存调试任务。Valgrind的体系结构如下图所示:

Valgrind包括如下一些工具:

  1. Memcheck。这是valgrind应用最广泛的工具,一个重量级的内存检查器,能够发现开发中绝大多数内存错误使用情况,比如:使用未初始化的内存,使用已经释放了的内存,内存访问越界等。这也是本文将重点介绍的部分。
  2. Callgrind。它主要用来检查程序中函数调用过程中出现的问题。
  3. Cachegrind。它主要用来检查程序中缓存使用出现的问题。
  4. Helgrind。它主要用来检查多线程程序中出现的竞争问题。
  5. Massif。它主要用来检查程序中堆栈使用中出现的问题。
  6. Extension。可以利用core提供的功能,自己编写特定的内存调试工具。

Linux 程序内存空间布局

要发现Linux下的内存问题,首先一定要知道在Linux下,内存是如何被分配的?下图展示了一个典型的Linux C程序内存空间布局:

一个典型的Linux C程序内存空间由如下几部分组成:

  • 代码段(.text)。代码段(code segment/text segment)通常是指用来存放程序执行代码的一块内存区域。这里存放的是CPU要执行的指令。代码段是可共享的,相同的代码在内存中只会有一个拷贝,同时这个段是只读的,防止程序由于错误而修改自身的指令(某些架构也允许代码段为可写,即允许修改程序)。在代码段中,也有可能包含一些只读的常数变量,例如字符串常量等。 因此,这部分区域的大小在程序运行前就已经确定,并且内存区域通常属于只读。
  • 初始化数据段(.data)。数据段(data segment)通常是指用来存放程序中已初始化的全局变量的一块内存区域。这里存放的是程序中需要明确赋初始值的变量,例如位于所有函数之外的全局变量:int val="100"。需要强调的是,以上两段都是位于程序的可执行文件中,内核在调用exec函数启动该程序时从源程序文件中读入。属于静态内存分配。
  • 未初始化数据段(.bss)bss段(bss[Block Started by Symbol] segment)通常是指用来存放程序中未初始化的全局变量的一块内存区域。位于这一段中的数据,内核在执行该程序前,将其初始化为0或者null。例如出现在任何函数之外的全局变量:int sum;属于静态内存分配。
  • 堆(Heap)。这个段用于在程序中进行动态内存申请,例如经常用到的malloc,new系列函数就是从这个段中申请内存。进属于动态内存分配,程运行中被动态分配的内存段,它的大小并不固定,可动态扩张或缩减。
  • 栈(Stack)。函数中的局部变量以及在函数调用过程中产生的临时变量都保存在此段中。我们函数括弧“{}”中定义的变量(但不包括static声明的变量,static意味着在数据段中存放变量)。除此以外,在函数被调用时,其参数也会被压入发起调用的进程栈中,并且待到调用结束后,函数的返回值也会被存放回栈中。由于栈的先进先出(FIFO)特点,所以栈特别方便用来保存/恢复调用现场。从这个意义上讲,我们可以把堆栈看成一个寄存、交换临时数据的内存区。

一个程序本质上都是由 bss段、data段、text段三个组成的。

在嵌入式系统的设计中,bss段通常是指用来存放程序中未初始化的全局变量的一块内存区域,一般在初始化时bss 段部分将会清零。bss段属于静态内存分配,即程序一开始就将其清零了。C语言之类的程序编译完成之后,已初始化的全局变量保存在.data 段中,未初始化的全局变量保存在.bss 段中。

text和data段都在可执行文件中(在嵌入式系统里一般是固化在镜像文件中),由系统从可执行文件中加载;而bss段不在可执行文件中,由系统初始化。

内存检查原理

Memcheck检测内存问题的原理如下图所示:

Memcheck 能够检测出内存问题,关键在于其建立了两个全局表。

  1. Valid-Value 表:

对于进程的整个地址空间中的每一个字节(byte),都有与之对应的 8 个 bits;对于 CPU 的每个寄存器,也有一个与之对应的 bit 向量。这些 bits 负责记录该字节或者寄存器值是否具有有效的、已初始化的值。

  1. Valid-Address 

对于进程整个地址空间中的每一个字节(byte),还有与之对应的 1 个 bit,负责记录该地址是否能够被读写。

检测原理:

  • 当要读写内存中某个字节时,首先检查这个字节对应的 A bit。如果该A bit显示该位置是无效位置,memcheck 则报告读写错误。
  • 内核(core)类似于一个虚拟的 CPU 环境,这样当内存中的某个字节被加载到真实的 CPU 中时,该字节对应的 V bit 也被加载到虚拟的 CPU 环境中。一旦寄存器中的值,被用来产生内存地址,或者该值能够影响程序输出,则 memcheck 会检查对应的V bits,如果该值尚未初始化,则会报告使用未初始化内存错误

#内存泄露# #valgrind# valgrind简介相关推荐

  1. Valgrind 检测linux上c++内存泄露

    Linux c++上常用内存泄露检测工具有valgrind, Rational purify.Valgrind免费.Valgrind 可以在 32 位或 64 位 PowerPC/Linux 内核上工 ...

  2. Valgrind 检测linux上c++内存泄露(转)

    Linux c++上常用内存泄露检测工具有valgrind, Rational purify.Valgrind免费.Valgrind 可以在 32 位或 64 位 PowerPC/Linux 内核上工 ...

  3. 动态内存检测工具Valgrind

    1. Valgrind查找内存泄露利器 Valgrind是一个GPL的软件,用于Linux(For x86, amd64 and ppc32)程序的内存调试和代码剖析.你可以在它的环境中运行你的程序来 ...

  4. Linux下内存泄露排查讨论

    作为c的程序员,最常见的就是排查内存泄漏,不过我们一般的内存泄漏是针对特定的程序去排查,相对来说比较容易,但是如果是维护人员,不知道哪个程序有内存泄漏,甚至是应用程序的内存泄漏,还是内核的内存泄漏都不 ...

  5. troubleshoot之:使用JFR解决内存泄露

    文章目录 简介 一个内存泄露的例子 使用JFR和JMC来分析内存泄露 OldObjectSample 总结 简介 虽然java有自动化的GC,但是还会有内存泄露的情况.当然java中的内存泄露跟C++ ...

  6. 使用valgrind检测ATS插件中的内存泄露

    一.内存错误出现的场景 这几天在重构ATS插件代码的过程中遇到了烦人的内存泄露问题, 周五周六连续两天通过走查代码的方法,未能看出明显的导致内存错误的代码, 同时也觉得C和C++混合编程得到一个动态库 ...

  7. 在Ubuntu 14.04 64bit上安装Valgrind并检查内存泄露

    valgrind官网:http://valgrind.org/ 1.安装方法 第一种方式:下载目前最新的源码,编译安装,在服务器上推荐这种方式 wget http://valgrind.org/dow ...

  8. Ubuntu下内存泄露检测工具Valgrind的使用

    在VS中可以用VLD检测是否有内存泄露,可以参考http://blog.csdn.net/fengbingchun/article/details/44195959,下面介绍下Ubuntu中内存泄露检 ...

  9. valgrind 报告 ecpg内存泄露 (三)

    valgrind为何 报 ecpg内存泄露错误?根据我的同事的研究成果: 究其原因,全局变量 sqlca 由malloc形成,但是释放时是隐含的: ecpg_sqlca_key_destructor函 ...

最新文章

  1. RecursionError: maximum recursion depth exceeded
  2. Airbnb欺诈预测机器学习模型设计:准确率和召回率的故事
  3. AlphaGo:人工智能与深度学习
  4. 让数据中台飞起来—— Quick BI性能优化解决方案及实践
  5. Unknown system variable 'tx_isolation'报错
  6. ahp层次分析法软件
  7. vue对象深拷贝_JS 对象的深拷贝和浅拷贝
  8. Makefile中变量赋值方式
  9. ASP.NET 学习日志
  10. 我用Python写了一个做题软件控制台版。(支持Mod)
  11. 如何解压.bz2文件包
  12. Sprint周期开发总结
  13. 安装office未能启动服务器,Office 2010安装时遇到1920错误问题怎么解决?
  14. MFC关于*.rc和resource.h文件的巧妙运用
  15. java使用axis2调用webservice接口实例
  16. 图解设计模式- Mediator 模式
  17. 使用备份软件快速备份VMware虚拟机
  18. 手把手教你封杀恶意登录服务器的ip
  19. 苹果系统java小游戏_Mac自带小游戏怎么玩?
  20. CF 472B Mystical Mosaic

热门文章

  1. ACM日历题新版(界面修改+国际节日)
  2. 基于 DataOps 的运营商大数据平台探索
  3. IB文学:戏剧作品中的对比手法
  4. 干货 |如何优雅的在手机上进行Python编程
  5. Mysql配置文件my.cnf配置及配置参数详解
  6. LeetCode 316. Remove Duplicate Letters
  7. FinalShell离线激活
  8. [转]QNX系统-基于高通骁龙SA8155平台,中科创达发布智能驾驶舱3.0解决方案
  9. 中科创达怎么样-融合智能工业视觉平台再获奖项
  10. 星际争霸2免修改器修改绝对一劳永逸