首页 > 代码库 > opencv矩阵赋值函数copyTo、clone、重载元算赋=的比较

opencv矩阵赋值函数copyTo、clone、重载元算赋=的比较

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 'setTo'function:");
printMat(m1);//改变m2的值看是否影响m1的值。

m1.copyTo(m2);//copyTo赋值方式
m2.setTo(2.0);
printf("m1 val after using 'copyTo'function:");
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、重载元算赋=的比较