你是否正在寻找关于copyto的内容?让我把最完整的东西奉献给你:
标签:opencvcopytoclone矩阵赋值
opencv矩阵赋函数copyTo、clone、重载元算赋‘=’之间实现的功能相均是给不同的矩阵赋功能。copyto和clone函数基本相同,被赋的矩阵和赋矩阵之间空间独立,不共享同一空间。但是重载元算赋‘=’,被赋的矩阵和赋矩阵之间空间共享,改变任一个矩阵的,会同时影响到另一个矩阵。当矩阵作为函数的返回时其功能和重载元算赋‘=’相同,赋运算赋会给矩阵空间增加一次计数,所以函数变量返回后函数内部申请的变量空间并不会被撤销,在主函数中仍可以正常使用传递后的参数。具体的过程见下面的测试程序。
主函数:
Mat m1(5,5,CV_32F); m1.setTo(1.0); printf("m1 initialized val:"); printMat(m1); Mat m2; m2=m1.clone();//clone赋值方式 m2.setTo(2.0); printf("m1 val after using setTofunction:"); printMat(m1);//改变m2的值看是否影响m1的值。 m1.copyTo(m2);//copyTo赋值方式 m2.setTo(2.0); printf("m1 val after using copytofunction:"); printMat(m1); m2=m1; //‘=’赋值方式 m2.setTo(2.0); printf("m1 val after using =function:"); printMat(m1); Mat m3=test();//函数返回赋值方式 printf("m3 val:"); printMat(m3);
cv::Mat test()
{
cv::Mat filter_t(10,10,CV_32F);
filter_t.setTo(1.0);
return filter_t;
}
下面是运行结果图
下面是赋函数test,赋前后变量内存情况,红色框是Mat矩阵中空间指针,比较得出赋函数返回变量前后是共享同一空间,。虽然空间是在test函数中申请得到,但是由于返回赋会增加一次该空间的引用,所以同一块内存空间在主函数中依然可以使用,只不过跳出test函数后该内存空间引用较少一个再次变为1。
opencv矩阵赋值函数copyto、clone、重载元算赋=的比较
标签:opencvcopytoclone矩阵赋值
原文:
以上就是关于copyto的全部内容,相信你一定会非常满意。
本文来自电脑杂谈,转载请注明本文网址:
http://www.pc-fly.com/a/ruanjian/article-445-1.html
一头黑发特别有神