[英]How to debug high memory consumption
我编写了一个使用OpenCV持久性模块读取.xml.gz文件的程序。 我使用一个类来管理这些数据。 在构造函数中,它使用cv::FileStorage
读取所有数据。 所有数据都在成员变量中,这些成员变量可以是std::vector
或cv::Mat
。 在类的每个实例之间没有静态成员或任何共享的对象。
这是奇怪的事情。 如果仅使用类的一个实例,则该程序将消耗约50MB的内存。 但是,如果我使用两个实例,它将消耗约600MB。 如果我使用三个,它将消耗大约650MB。 如果使用四个,则将消耗约700MB的内存。似乎只有一个实例与多个实例之间存在奇怪的界限。
我做了一些实验,下面是一些结果:
这是此类的代码: https : //github.com/delphifirst/FaceX/blob/master/FaceX/face_x.cpp
在我的代码中指出问题或为我提供一些调试此类问题的建议都将非常有帮助。
编辑:我遵循注释中的建议,并使用top -p而不是gnome-system-monitor来检查内存消耗。 结果是:VIRT:1003552,RES:693228,SHR:8440,%MEM:33.8(计算机总共有2GB内存)
Edit2:我使用tcmalloc替换g ++的内存分配器,然后问题神秘地消失了。
您可以链接到tcmalloc(一个内存分配库,它将替换程序中的常规内存分配例程)并使用其堆分析器。 堆分析器将告诉您内存消耗的来源(即程序中的哪些函数正在分配所有内存)。 这将为您进行进一步调试提供一个良好的起点。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.