void CDifTest::tESecSpaMomTest_avg(const string & imgPath, const int nImgNum, vector<Point2f>& ellipseCentersL, vector<Point2f>& ellipseCentersM, vector<Point2f>& ellipseCentersR, string & resultFileName)
{
ellipseCentersL.clear(); ellipseCentersM.clear(); ellipseCentersR.clear();
vector<string> imgNames;
CMethodBase::GetFiles(imgPath, imgNames);
Point2f ellipseCenterL, ellipseCenterM, ellipseCenterR;
vector<Mat> srcImgs;
for (int i = 0; i < nImgNum; i++)
{
long t1 = GetTickCount();
CImgThrEllip* pImgThrEllip = new CImgThrEllip(imgNames[i]);//具体的接受者
CSpatialMoment* pSpatialMoment = new CSpatialMoment(pImgThrEllip);//根据类型确定方法
//获取分割后的菱形和椭圆,以及初始点坐标
vector<Mat> ellipses = pImgThrEllip->GetEllipses();
vector<Point> elliSegBegs = pImgThrEllip->GetElliSegBegs();
Mat srcImg = pImgThrEllip->GetSrcImage();
//srcImgs.push_back(srcImg);
ellipseCenterL = pSpatialMoment->calCenterTest(ellipses[0], SHAPE_ONE_SEC_ELLIPSE);
ellipseCenterM = pSpatialMoment->calCenterTest(ellipses[1], SHAPE_ONE_SEC_ELLIPSE);
ellipseCenterR = pSpatialMoment->calCenterTest(ellipses[2], SHAPE_ONE_SEC_ELLIPSE);
ellipseCenterL = pSpatialMoment->CoordRecovery(ellipseCenterL, elliSegBegs[0]);
ellipseCenterM = pSpatialMoment->CoordRecovery(ellipseCenterM, elliSegBegs[1]);
ellipseCenterR = pSpatialMoment->CoordRecovery(ellipseCenterR, elliSegBegs[2]);
ellipseCentersL.push_back(ellipseCenterL);
ellipseCentersM.push_back(ellipseCenterM);
ellipseCentersR.push_back(ellipseCenterR);
delete pImgThrEllip;
delete pSpatialMoment;
pImgThrEllip = nullptr;
pSpatialMoment = nullptr;
long t2 = GetTickCount();
cout << "第" << i + 1 << "张图片运行时间: " << (t2 - t1) << endl;
}
int n = 10;
vector<Point2f> avgEllipseCentersL, avgEllipseCentersM, avgEllipseCentersR;
avgEllipseCentersL = CMethodBase::CalCentersAvg(ellipseCentersL, n);
avgEllipseCentersM = CMethodBase::CalCentersAvg(ellipseCentersM, n);
avgEllipseCentersR = CMethodBase::CalCentersAvg(ellipseCentersR, n);
CMethodBase::WriteThrCenterToFile(resultFileName, avgEllipseCentersL, avgEllipseCentersM, avgEllipseCentersR);
}
此段程序中,在for循环内,向vector<>中不断压入图片,所以会造成程序内存在缓慢稳步增加!
并不是因为内存为释放!!!防止思维惯性,一般内存泄漏会造成程序崩溃,如果不崩溃有可能是因为其他的问题。