Linux内存泄漏检查工具

Linux内存泄漏检查工具

内存泄漏分类

1、常发性内存泄漏

发生内存泄漏的代码会被多次执行到,每次被执行的时候都会导致一块内存泄漏。

2、偶发性内存泄漏

发生内存泄漏的代码只有在某些特定环境或操作过程下才会发生。常发性和偶发性是相对的。对于特定的环境,偶发性的也许就变成了常发性的。所以测试环境和测试方法对检测内存泄漏至关重要。

3、 一次性内存泄漏

发生内存泄漏的代码只会被执行一次,或者由于算法上的缺陷,导致总会有一块且仅一块内存发生泄漏。比如,在一个Singleton类的构造函数中分配内存,在析构函数中却没有释放该内存。而Singleton类只存在一个实例,所以内存泄漏只会发生一次。

4、 隐式内存泄漏

程序在运行过程中不停的分配内存,但是直到结束的时候才释放内存。严格的说这里并没有发生内存泄漏,因为最终程序释放了所有申请的内存。但是对于一个服务器程序,需要运行几天,几周甚至几个月,不及时释放内存也可能导致最终耗尽系统的所有内存。所以,我们称这类内存泄漏为隐式内存泄漏。

内存泄漏检测工具

现在有很多方法来检测内存泄露,以下列举了linux常用的内存泄露检测工具。

1、mtrace

应用环境:Linux GLIBC

编程语言:C

使用方法: 包含头文件mcheck.h,定义环境变量MALLOC_TRACE为输出文件名,程序开始时调用mtrace()即可。

结果输出:用户指定的文件

设计思路: 为malloc,realloc,free函数添加钩子函数,记录每一对malloc-free的执行

优缺点:只能检查使用malloc/realloc/free造成的的内存泄露

如何获取:GLIBC自带,可直接使用

2、memwatch

应用环境:Linux

编程语言:C

使用方法: 加入memwatch.h,编译时加上-DMEMWATCH -DMW_STDIO及memwatch.c

结果输出:输出文件名称为memwatch.log,在程序执行期间,错误提示都会显示在stdout上

设计思路:将malloc/realloc/calloc/strdup/free等重定义为mwMalloc(sz, FILE, LINE)等,内部维护一个操作链表

优缺点:能检测双重释放(double-free)、错误释放(erroneous free)、内存泄漏(unfreed memory)、溢出(Overflow)、下溢(Underflow)等等

如何获取:链接: link

3、valgrind

应用环境:Linux

编程语言:C/C++

使用方法: 编译时加上-g选项,如 gcc -g filename.c -o filename,使用如下命令检测内存使用情况:

结果输出:#valgrind --tool=memcheck --leak-check=yes --show-reachable=yes ./filename,就会看到内存使用报告

设计思路:根据软件的内存操作维护一个有效地址空间表和无效地址空间表(进程的地址空间)

优缺点:能够检测:

使用未初始化的内存 (Use of uninitialised memory)

使用已经释放了的内存 (Reading/writing memory after it has been free’d)

使用超过 malloc分配的内存空间(Reading/writing off the end of malloc’d blocks)

对堆栈的非法访问 (Reading/writing inappropriate areas on the stack)

申请的空间是否有释放 (Memory leaks – where pointers to malloc’d blocks are lost forever)

malloc/free/new/delete申请和释放内存的匹配(Mismatched use of malloc/new/new [] vs free/delete/delete [])

src和dst的重叠(Overlapping src and dst pointers in memcpy() and related functions)

重复free

如何获取:链接: link

4、debug_new

应用环境:Linux/Windows

编程语言:C++

使用方法:包含头文件debug_new.h,链接debug_new.cpp

结果输出:控制台console

设计思路:通过重载new和delete操作符来捕获内存申请/释放请求,并在程序内部维护一个全局静态变量的哈希链表。在new操作符中,不仅仅分配用户所要求的内存,而是在为每次分配的内存都添加一个头部,存储着此次分配的位置信息和链表指针,new返回的是分配的这块内存加上头部偏移后的值,而在之前已经将此返回值作了HASH计算并添加到HASH链表中了。delete的时候先根据要释放的指针地址做HASH计算,然后再遍历数组HASH值处的链表进行查找,如果找到则将该节点移除,未找到就abort。这样在程序结束之后,通过检查此数组中是否还有未释放的内存块来确定是否有内存泄露。

优缺点:跨平台,仅用于C++程序,

如何获取:链接: link

总结

以上的这些分析工具,所使用的方法大致分为以下几种:

1、注册内存分配/释放钩子函数(hook)。在Linux下可以malloc_hook, free_hook等5个钩子函数,在Windows下可以注册_CrtSetAllocHook钩子函数,这样在分配内存的时候就可以捕获这一请求并加以处理。Visual Leak Detecter和mtrace使用此方式。

2、使用宏定义替换。将用户代码中的malloc, free 替换为宏定义的 mwMalloc(sz, FILE, LINE)等自定义函数,从而跟踪内存请求,memwatch即使用此方式。

3、操作符重载。此方法仅用于C++语言中,通过重载new、delete操作符来实现跟踪内存请求,重载后的操作符类似于钩子函数意义。debug_new采用此方式。

这些工具的输出方式也分以下几种:

1、普通环境下一般输出到调试窗口中,很多软件本身就提供了一个理想的输出场所,并且GUI应用程序输出到标准输出时不可见的。Visual Leak Detecter采用此法。

2、输出到标准输出或标准错误输出:控制台应用程序可以输出到屏幕,如memwatch, valgrind, debug_new都是采用这种方法。

3、输出到日志文件:将结果输出到用户指定或默认的日志文件中,如mtrace和memwatch。

此外,这些工具的内存检测方式无非也分为两种:

1、维护一个内存操作链表,当有内存申请操作时,将其加入此链表中,当有释放操作时,从申请操作从链表中移除。如果到程序结束后此链表中还有内容,说明有内存泄露了;如果要释放的内存操作没有在链表中找到对应操作,则说明是释放了多次。使用此方法的有内置的调试工具,Visual Leak Detecter,mtrace, memwatch, debug_new。

2、模拟进程的地址空间。仿照操作系统对进程内存操作的处理,在用户态下维护一个地址空间映射,此方法要求对进程地址空间的处理有较深的理解。因为Windows的进程地址空间分布不是开源的,所以模拟起来很困难,因此只支持Linux。采用此方法的是valgrind。

分析较好的博客
链接: Linux下几款C++程序中的内存泄露检查工具

链接: linux中strace与GDB的乐趣

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以通过使用内存泄漏检查工具检查Linux系统中的内存泄漏问题。通常使用的工具有Valgrind、DMalloc和Mtrace等,使用它们可以定位出哪些代码、变量或调用等引起内存泄漏,并及时修复解决问题。内存泄漏问题不仅会导致系统性能下降和程序运行效率低下,还可能导致系统崩溃,因此及时解决内存泄漏问题尤为重要。 ### 回答2: Linux内存泄露指的是程序在运行过程中未及时释放内存资源所导致的问题。由于内存资源是有限的,内存泄露可能会导致程序运行变慢甚至崩溃。因此,检查和及时修复内存泄露是保证程序高效稳定运行的重要要求之一。 在Linux中,内存泄露的检查可以通过多种工具来实现。其中最常用的工具是valgrind。valgrind是一款基于动态二进制插桩技术的内存调试和分析工具,可以检测程序使用内存的情况,包括内存泄漏、未初始化的内存、读/写越界和使用已释放内存等问题。valgrind支持多种编程语言,例如C、C++、Java等。 使用valgrind进行内存泄漏检查,可以通过以下步骤实现: 1. 在终端中输入命令“valgrind --leak-check=full ./可执行文件名”,其中“--leak-check=full”表示开启内存泄漏检查模式,“./可执行文件名”表示要检查的可执行文件的路径和名称。 2. 运行程序,当程序结束时,valgrind会输出内存泄漏的相关信息,包括泄漏的内存地址、大小、泄漏时的代码位置等。同时,valgrind还会生成一个报告文件,提供更详细的泄漏信息和其他问题。 3. 根据输出信息,定位内存泄漏的原因,并进行修复。 总之,内存泄漏是一个非常常见的程序错误,也是严重的问题之一。通过使用valgrind等工具进行内存泄漏检查,可以帮助程序员快速定位并解决内存泄漏问题,从而提高程序的性能和稳定性。 ### 回答3: Linux 内存泄漏检查是一项非常重要的任务,因为内存泄漏可能导致系统的崩溃和数据的丢失,而且通常很难追踪和修复。 内存泄漏是指在分配内存时,程序未正确释放其使用的内存。 这意味着这些内存块将一直存在,直到系统重新启动或进程被杀死。由于内存泄漏会导致系统崩溃,因此必须对其进行检查。 有几种工具可用于检查 Linux 上的内存泄漏。其中最常见的是 Valgrind。 Valgrind 是一款调试和性能工具,可检查 C/C++ 代码的内存泄漏以及许多其他类型的内存问题。Valgrind 采用动态二进制翻译(DBT)技术,可以模拟 CPU,并通过这种方式将软件运行在虚拟 CPU 上。由于 Valgrind 在虚拟 CPU 上运行,因此它可以检测和拦截访问内存的软件错误,而这些错误可能会导致崩溃、内存泄漏等问题。 另一个流行的工具是 Massif。Massif 是一个 Valgrind 编写的堆分析程序,可用于检查堆的使用情况,以帮助发现内存泄漏。它会收集信息并生成有关程序使用的堆的图表和统计信息,从而帮助开发人员更容易地找出问题并修复它们。 除了 Valgrind 和 Massif,还有一些其他工具可用于检查内存泄漏,例如 AddressSanitizer 和 LeakSanitizer。无论使用哪种工具,都必须确保测试程序具有足够的复杂性和具有代表性,以使测试结果具有实用价值。 在 Linux 上进行内存泄漏检查是一项艰巨的任务,但使用正确的工具和方法可以大大简化它。通过使用这些工具和方法,您可以找出并修复程序中的内存泄漏,确保系统稳定和数据的安全。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值