zoukankan      html  css  js  c++  java
  • Qt creator 搭配 valgrind 检测内存泄漏

      继上次重载operator new检测内存泄漏失败之后,妥协了。决定不管是否是准确指明哪一行代码出现内存泄漏,只要告诉我是否有泄漏就行了,这样就没有new替换的问题。在开发中,总是一个个小功能的开发。如果开发完一个小功能告诉我有内存泄漏,那想必也是比较容易找的。

      这次的想法是重写operator new,然后每次new的时候记录一下地址及申请内存的大小,释放时删除记录。这样,程序结束时剩余的记录就是泄漏的了。记录的数据结构首选STL的map。结果,在记录时,map需要申请内存,调用new,new需要调用map来记录...居然成了死循环。又得放弃了。

      不过总得有个方案检测程序的内存泄漏啊。malloc_hook、mtrace、valgrind得选一个了。感觉malloc_hook有点类似重写operator new,不想用。mtrace每次要生成文件记录,不方便经常调试。也只有valgrind一个选择了。之前不用valgrind是因为自己代码用的库比较多,libev、boost、STL...,其中libev文档指明valgrind对它的检测结果有误,所以开始不用。不过现在也无所谓了,知道有这么回事就好。

      Qt creator和valgrind是分开的,确保已安装valgrind,没安装的请sudo apt-get install valgrind。

      故意写了内存泄漏的代码“char *pttt = new char[1024];”:

      点击Qt creator 中的分析菜单,选中Valgrind Memory Analyzer

    Qt creator 会调用valgrind自动分析中,如果程序比较大,可能会很慢

      可见valgrind可以将基本的内存泄漏分析出来。但是,工具检测只是提供了参考,对于复杂的程序,尤其是使用了内存池的程序。重要的还是自己写代码时注意。

  • 相关阅读:
    linux 系统中 获取环境变量、 获取环境变量+自定义变量
    即兴写作系统
    php 解决旧系统 查出所有数据分页的类
    面向过程与面向对象编程思想的区别
    c语言入门(一)c语言基础
    清数据库日志
    使用数据集时错误:超时时间已到。在操作完成之前超时时间已过或服务器未响应。
    数据库 可疑 解决方法
    [转].Net线程问题解答
    查询重复记录数
  • 原文地址:https://www.cnblogs.com/coding-my-life/p/4004161.html
Copyright © 2011-2022 走看看