在学习Date日期类的实现中,发现了一个之前不知道的点,就是在对后置++的运算符重载实现中,因为要区分于前置++,所以可以在函数形参列表中加入了一个int(而不是int 变量名),引发对c++形参名是否可以省略的思考。
⭕如下
// 后置++
Date operator++(int);//int类型变量是区分于前置的标志(C++函数声明时,形参可以没有参数名)
为此我做了如下试验:
1.函数声明定义不分离时
//.cpp文件
//运行报错,因为函数中要用到形参,此时不能省略形参名
void Print(int, int)
{
cout << a << b << endl;
}
int main()
{
int a = 0;
int b = 1;
Print(a, b);
return 0;
}
//运行通过,因为函数中没有用到形参,此时可以省略形参名
void Print(int, int)
{
cout << 10 << endl;
}
int main()
{
int a = 0;
int b = 1;
Print(a, b);
return 0;
}
因此,函数operator++(int)能省略形参名的原因是其内部没有用到形参,只是将这个int类型的形参作为一个标志用于区分开前置++和后置++。
2.函数声明定义分离时
//也是一样的,函数内部没用到形参就可以省略,用到就不能
//函数内部没用到形参
//right
void Print(int , int);
int main()
{
int a = 0;
int b = 1;
Print(a, b);
return 0;
}
void Print(int , int)
{
cout << 10 << endl;
}
//声明和定义只省略一处也是正确的(省略哪一处都行,没有影响)
void Print(int a, int b);
int main()
{
int a = 0;
int b = 1;
Print(a, b);
return 0;
}
void Print(int, int)
{
cout << 10 << endl;
}
//函数内部用到形参
//error
void Print(int , int);
int main()
{
int a = 0;
int b = 1;
Print(a, b);
return 0;
}
void Print(int , int)
{
cout << a << b << endl;
}
在c++中只要是函数内部没用到形参的都可以省略函数形参名,但在c语言中却有所差异。
c语言代码
//error
//函数内部没用到形参,但也不能省略
void Print(int, int)
{
printf("%d", 10);
}
int main()
{
int a = 0;
int b = 1;
Print(a, b);
return 0;
}
而当声明与定义分离时,声明却可以省略。
//right
void Print(int, int);
int main()
{
int a = 0;
int b = 1;
Print(a, b);
return 0;
}
void Print(int a, int b)
{
printf("%d", 10);
}
//即使函数定义用到形参名,也是可以的
void Print(int, int);
int main()
{
int a = 0;
int b = 1;
Print(a, b);
return 0;
}
void Print(int a, int b)
{
printf("%d %d", a, b);
}
因此得出结论,在C语言中,在函数存在定义的地方,就不能省略形参名。
综上所述
1️⃣在函数声明中:
不管是C还是在C++,都可以省略形参名,但通常都不建议省略形参名。
2️⃣在函数定义中:
当需要使用形参时,必须给形参命名。
当不需要使用形参时,C与C++有微小差异:
C不能省略形式参数名, 即使不使用;
C++可以省略形式参数名,如果不使用。