C++ opencv名称:泄漏(c+;+;和opencv)

C++ opencv名称:泄漏(c+;+;和opencv),c++,opencv,C++,Opencv,运行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::destr

运行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);

}
当我显示图像时,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);
感谢您的帮助。
询问您需要的更多信息。

实际上您不需要再打电话给
namedWindow
。您只需调用“裸”cv::imshow(windowname,m_image)。即使覆盖,也可以正常工作

备注:
waitKey
有两种用法:
1.永远等待,然后
waitKey(0)

2.请稍等片刻,可能是因为您正在显示来自网络摄像头的输入。然后执行
waitKey(30)(或更少,取决于播放内容的fps。对于电影,为30。)

抱歉,严酷的现实看起来像OpenCV泄漏。根据leaks Instrument(XCode工具),由于自参考,它也从Qt接口的侧面泄漏


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

我将进一步研究它。没错,最终我们发现它是OpenCV本身的一个漏洞。