求大神帮忙寻找c++、opencv处理视频的内存泄漏问题,实在实在找不出了

qq_21019127 2015-12-07 09:51:52
对于每一位进来的神,妹纸在这里先感谢了~~~~~
// OpenCVFindContours.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include "cxcore.h"
#include "cv.h"
#include "highgui.h"

int _tmain(int argc, _TCHAR* argv[])
{
CvCapture* pCapture = cvCreateCameraCapture(0);
IplImage * pFrame;
IplImage *psrc;
IplImage *src = cvCreateImage(cvSize(700,700), IPL_DEPTH_8U,3);
IplImage *gsrc = cvCreateImage(cvGetSize(src), IPL_DEPTH_8U,1);

IplImage *dsw ;
IplImage *dst;
CvMemStorage *storage;
CvSeq *first_contour;

while(1)
{
psrc=cvQueryFrame(pCapture );

cvResize(psrc,src,1);
cvCvtColor(src,gsrc,CV_BGR2GRAY);

dsw = cvCreateImage(cvGetSize(src), 8, 1);
dst = cvCreateImage(cvGetSize(src), 8, 3);

storage = cvCreateMemStorage(0);
first_contour = NULL;

//turn the src image to a binary image
//cvThreshold(src, dsw, 125, 255, CV_THRESH_BINARY_INV);
cvThreshold(gsrc, dsw, 100, 255, CV_THRESH_BINARY);

cvFindContours(dsw, storage, &first_contour, sizeof(CvContour), CV_RETR_LIST, CV_CHAIN_APPROX_SIMPLE);
cvZero(dst);
int cnt = 0;
for(; first_contour != 0; first_contour = first_contour->h_next)
{
cnt++;
CvScalar color = CV_RGB(rand()&255, rand()&255, rand()&255);
cvDrawContours(dst, first_contour, color, color, 0, 2, CV_FILLED, cvPoint(0, 0));
CvRect rect = cvBoundingRect(first_contour,0);
cvRectangle(dst, cvPoint(rect.x, rect.y), cvPoint(rect.x + rect.width, rect.y + rect.height),CV_RGB(255, 0, 0), 1, 8, 0);
}

printf("the num of contours : %d\n", cnt);

cvNamedWindow( "Source", 1 );
cvShowImage( "Source", src );

cvNamedWindow( "dsw", 1 );
cvShowImage( "dsw", dsw );

cvNamedWindow( "Components", 1 );
cvShowImage( "Components", dst );

cvReleaseMemStorage(&storage);

char c=cvWaitKey(10);
if(c==27)
break;
}

cvDestroyWindow("Source");
cvDestroyWindow("dsw");
cvDestroyWindow("Components");

cvReleaseImage(&pFrame);
cvReleaseImage(&gsrc);
cvReleaseImage(&src);
cvReleaseImage(&dsw);
cvReleaseImage(&dst);

//cvReleaseMemStorage(&storage);
cvReleaseCapture(&pCapture);

return 0;
}


求寻找内存泄漏之处~
...全文
127 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
qq_21019127 2015-12-07
  • 打赏
  • 举报
回复
引用 1 楼 chehw_1的回复:


 
int main(int argc, char * argv[])
{
    CvCapture* pCapture = cvCreateCameraCapture(0);
    IplImage * pFrame;
    IplImage *psrc;
    IplImage *src = cvCreateImage(cvSize(700,700), IPL_DEPTH_8U,3);
    IplImage *gsrc = cvCreateImage(cvGetSize(src), IPL_DEPTH_8U,1);
     
    IplImage *dsw ;
    IplImage *dst;
    CvMemStorage *storage;
    CvSeq *first_contour;
     
    while(1)
    {
        psrc=cvQueryFrame(pCapture ); 
         
        cvResize(psrc,src,1);
        cvCvtColor(src,gsrc,CV_BGR2GRAY);
 
        dsw = cvCreateImage(cvGetSize(src), 8, 1);  
        dst = cvCreateImage(cvGetSize(src), 8, 3);
 
        storage = cvCreateMemStorage(0);  
        first_contour = NULL;  
 
        //turn the src image to a binary image  
        //cvThreshold(src, dsw, 125, 255, CV_THRESH_BINARY_INV);  
        cvThreshold(gsrc, dsw, 100, 255, CV_THRESH_BINARY);  
 
        cvFindContours(dsw, storage, &first_contour, sizeof(CvContour), CV_RETR_LIST, CV_CHAIN_APPROX_SIMPLE);  
        cvZero(dst);  
        int cnt = 0;  
        for(; first_contour != 0; first_contour = first_contour->h_next)  
        {  
            cnt++;  
            CvScalar color = CV_RGB(rand()&255, rand()&255, rand()&255);  
            cvDrawContours(dst, first_contour, color, color, 0, 2, CV_FILLED, cvPoint(0, 0));  
            CvRect rect = cvBoundingRect(first_contour,0);
            cvRectangle(dst, cvPoint(rect.x, rect.y), cvPoint(rect.x + rect.width, rect.y + rect.height),CV_RGB(255, 0, 0), 1, 8, 0);
        }  
 
        printf("the num of contours : %d\n", cnt);  
 
        cvNamedWindow( "Source", 1 );  
        cvShowImage( "Source", src );  
 
        cvNamedWindow( "dsw", 1 );  
        cvShowImage( "dsw", dsw );  
 
        cvNamedWindow( "Components", 1 );  
        cvShowImage( "Components", dst );  
 
		cvReleaseMemStorage(&storage);
		
		cvReleaseImage(&dsw);  // 应移至此处
		cvReleaseImage(&dst); // 应移至此处
 
        char c=cvWaitKey(10);
        if(c==27)
            break;   
    }
 
    cvDestroyWindow("Source");
    cvDestroyWindow("dsw");
    cvDestroyWindow("Components");
 
    //~ cvReleaseImage(&pFrame); //cvReleaseCapture会释放,千万别自己处理
    cvReleaseImage(&gsrc);
    cvReleaseImage(&src);
    
 
    //cvReleaseMemStorage(&storage);
    cvReleaseCapture(&pCapture);
 
    return 0;  
}


大神,真的是无比感谢
chehw_1 2015-12-07
  • 打赏
  • 举报
回复


 
int main(int argc, char * argv[])
{
    CvCapture* pCapture = cvCreateCameraCapture(0);
    IplImage * pFrame;
    IplImage *psrc;
    IplImage *src = cvCreateImage(cvSize(700,700), IPL_DEPTH_8U,3);
    IplImage *gsrc = cvCreateImage(cvGetSize(src), IPL_DEPTH_8U,1);
     
    IplImage *dsw ;
    IplImage *dst;
    CvMemStorage *storage;
    CvSeq *first_contour;
     
    while(1)
    {
        psrc=cvQueryFrame(pCapture ); 
         
        cvResize(psrc,src,1);
        cvCvtColor(src,gsrc,CV_BGR2GRAY);
 
        dsw = cvCreateImage(cvGetSize(src), 8, 1);  
        dst = cvCreateImage(cvGetSize(src), 8, 3);
 
        storage = cvCreateMemStorage(0);  
        first_contour = NULL;  
 
        //turn the src image to a binary image  
        //cvThreshold(src, dsw, 125, 255, CV_THRESH_BINARY_INV);  
        cvThreshold(gsrc, dsw, 100, 255, CV_THRESH_BINARY);  
 
        cvFindContours(dsw, storage, &first_contour, sizeof(CvContour), CV_RETR_LIST, CV_CHAIN_APPROX_SIMPLE);  
        cvZero(dst);  
        int cnt = 0;  
        for(; first_contour != 0; first_contour = first_contour->h_next)  
        {  
            cnt++;  
            CvScalar color = CV_RGB(rand()&255, rand()&255, rand()&255);  
            cvDrawContours(dst, first_contour, color, color, 0, 2, CV_FILLED, cvPoint(0, 0));  
            CvRect rect = cvBoundingRect(first_contour,0);
            cvRectangle(dst, cvPoint(rect.x, rect.y), cvPoint(rect.x + rect.width, rect.y + rect.height),CV_RGB(255, 0, 0), 1, 8, 0);
        }  
 
        printf("the num of contours : %d\n", cnt);  
 
        cvNamedWindow( "Source", 1 );  
        cvShowImage( "Source", src );  
 
        cvNamedWindow( "dsw", 1 );  
        cvShowImage( "dsw", dsw );  
 
        cvNamedWindow( "Components", 1 );  
        cvShowImage( "Components", dst );  
 
		cvReleaseMemStorage(&storage);
		
		cvReleaseImage(&dsw);  // 应移至此处
		cvReleaseImage(&dst); // 应移至此处
 
        char c=cvWaitKey(10);
        if(c==27)
            break;   
    }
 
    cvDestroyWindow("Source");
    cvDestroyWindow("dsw");
    cvDestroyWindow("Components");
 
    //~ cvReleaseImage(&pFrame); //cvReleaseCapture会释放,千万别自己处理
    cvReleaseImage(&gsrc);
    cvReleaseImage(&src);
    
 
    //cvReleaseMemStorage(&storage);
    cvReleaseCapture(&pCapture);
 
    return 0;  
}


69,382

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧