6

运行 valgrind,我在 opencv 中发现大量内存泄漏,尤其是使用 namedWindow 的功能。

总的来说,我有一个图像 CSImg 和 PGImg:

std::string cs = "Computer Science Students";
std::string pg = "Politics and Government Students";
CSImg.displayImage(cs);
cv::destroyWindow(cs);
PGImg.displayImage(pg);
cv::destroyWindow(pg);

显示图像功能是:

void ImageHandler::displayImage(std::string& windowname){
namedWindow(windowname);
imshow(windowname, m_image);
waitKey(7000);

}

当我做 displayImage 时,Valgrind 给我带来了巨大的内存泄漏。例如:

==6561== 2,359,544 bytes in 1 blocks are possibly lost in loss record 3,421 of 3,421
==6561==    at 0x4C2B3F8: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==6561==    by 0x4F6C94C: cv::fastMalloc(unsigned long) (in /usr/lib/libopencv_core.so.2.3.1)
==6561==    by 0x4F53650: cvCreateData (in /usr/lib/libopencv_core.so.2.3.1)
==6561==    by 0x4F540F0: cvCreateMat (in /usr/lib/libopencv_core.so.2.3.1)
==6561==    by 0x56435AF: cvImageWidgetSetImage(_CvImageWidget*, void const*) (in /usr/lib/libopencv_highgui.so.2.3.1)
==6561==    by 0x5644C14: cvShowImage (in /usr/lib/libopencv_highgui.so.2.3.1)
==6561==    by 0x5642AF7: cv::imshow(std::string const&, cv::_InputArray const&) (in /usr/lib/libopencv_highgui.so.2.3.1)
==6561==    by 0x40CED7: ImageHandler::displayImage(std::string&) (imagehandler.cpp:33)
==6561==    by 0x408CF5: main (randomU.cpp:601)

imagehandler.cpp,第 33 行是:

imshow(windowname, m_image); //the full function is written above ^

randomU.cpp 第 601 行是:

CSImg.displayImage(cs);

任何帮助表示赞赏。询问您需要的任何进一步信息。

4

2 回答 2

2

抱歉,严峻的现实看起来像 OpenCV 泄漏。根据 Leaks Instrument(XCode 工具),由于自引用,它也会从其 Qt 界面的一侧泄漏。

其他证明这不仅仅是误报:在我的 Mac 上,Opencv 2.4.3 在处理网络摄像头输入时在内存中不断增长(根据活动监视器)。(我没有使用任何指针或数据存储,所以理论上我的 OpenCV 程序应该保持恒定大小。)

于 2012-12-08T12:26:59.333 回答
0

其实你不需要再打电话namedWindow了。你只是叫一个“裸体” cv::imshow(windowname,m_image)。即使你覆盖它也能正常工作。

备注:
waitKey有两种用法:
1. 永远等待,然后waitKey(0);
2. 稍等片刻,可能是因为您正在显示来自网络摄像头的输入。然后执行waitKey(30);(或更少,取决于您正在播放的内容的 fps。对于电影,30。)

于 2012-11-23T13:58:05.133 回答