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

  • 相关阅读:
    tp5项目后台比赛界面
    总结7.21 lavarel视图
    总结7.20 laravel自动验证
    java学习day78--JT项目16(CORS跨域/HttpCLient/jt-sso单点登录)
    java学习day77-JT项目15(Ajax跨域访问/JSONP)
    java学习day77-JT项目15(Redis集群算法/spring boot整合redis集群)
    java学习day76-JT项目14(Redis集群搭建)
    java学习day76-JT项目14(Redis分片机制/哨兵机制)
    检查Linux中发现没有IP
    java学习day75-JT项目13(AOP实现redis缓存/Redis缓存)
  • 原文地址:https://www.cnblogs.com/coding-my-life/p/4004161.html
Copyright © 2011-2022 走看看