今天写了一段代码,结果有一个bug坑了我一个上午。
先上错误代码
void Gussian_Filter(Mat SrcImage, Mat DstImage,uint Guassian_size)
{
double x_simga = 0;
double y_simga = 0;
cout << "请输入x方向的径向因子,其为一个浮点数" << endl;
cin >> x_simga;
cout << "请输入y方向的径向因子,其为一个浮点数" << endl;
cin >> y_simga;
GaussianBlur(SrcImage, DstImage, Size(Guassian_size, Guassian_size), x_simga, y_simga);//高斯滤波
}
void Filter(Mat InputImage,uint size,uchar method)
{
Mat OutputImage;//定义保存结果图像矩阵
/*判断输入图像是否成功*/
if (!InputImage.data)
{
cout << "图像加载失败!" << endl;
}
/*判断掩码模板是否为奇数*/
else if (InputImage.data)
{
if (size % 2 == 0)
{
cout << "size作为一个掩码模板应该是奇数" << endl;
cout << "请重新输入size的值" << endl;
}
else if (size % 2 == 1)
{
imshow("origin", InputImage);
switch (method)
{
/*均值滤波*/
case 0: blur(InputImage, OutputImage,Size(size, size));break;
/*中值滤波*/
case 1:medianBlur(InputImage, OutputImage, size); break;
/*高斯滤波*/
case 2: Gussian_Filter(InputImage, OutputImage, size);break;
}
imshow("result", OutputImage);
}
}
waitKey(0);
}
然后就凉了,运行结构如下:
改正后函数:
void Gussian_Filter(Mat SrcImage, Mat &DstImage,uint Guassian_size)
{
double x_simga = 0;
double y_simga = 0;
cout << "请输入x方向的径向因子,其为一个浮点数" << endl;
cin >> x_simga;
cout << "请输入y方向的径向因子,其为一个浮点数" << endl;
cin >> y_simga;
GaussianBlur(SrcImage, DstImage, Size(Guassian_size, Guassian_size), x_simga, y_simga);//高斯滤波
}
有什么不一样了呢?
Gussian_Filter含参函数中多了一个取地址符。
void mysort(mat a)的a是值传递方式
值传递:
形参是实参的拷贝,改变形参的值并不会影响外部实参的值。从被调用函数的角度来说,值传递是单向的(实参->形参),参数的值只能传入,
不能传出。当函数内部需要修改参数,并且不希望这个改变影响调用者时,采用值传递。
void mysort(mat& a)的&a是引用传递方式
引用传递:
形参相当于是实参的“别名”,对形参的操作其实就是对实参的操作,在引用传递过程中,被调函数的形式参数虽然也作为局部变量在栈中开辟了内存空间,但是这时存放的是由主调函数放进来的实参变量的地址。被调函数对形参的任何操作都被处理成间接寻址,即通过
栈中存放的地址访问主调函数中的实参变量。正因为如此,被调函数对形参做的任何操作都影响了主调函数中的实参变量。