函数模板,是指函数名称相同,参数个数相同,函数体也相同,仅仅参数类型不同。
从上面定义来看,可以用函数模板实现的,肯定能用函数重载来实现,反之则不成立。
例如两个变量比较大小的功能。函数对于整形变量,和double变量可以用重载实现。
int compare(int a, int b)
{
if(a > b)
return 1;
else if(a == b)
return 0;
else
return -1;
}
int compare(double a, double b)
{
if(a > b)
return 1;
else if(a == b)
return 0;
else
return -1;
}
这种情况也可以用函数模板实现,因为上面两个函数的函数体完全相同。
int compare(T a, Tb)
{
if(a > b)
return 1;
else if(a == b)
return 0;
else
return -1;
}
但是明显这个时候用函数模板更好,因为避免了代码重复。在应用中体会两者的区别吧~
函数重载的定义:函数重载是指在同一作用域内,可以有一组具有相同函数名,不同参数列表的函数,这组函数被称为重载函数。
所以原则就是相同的函数名,不同的参数列表。返回值不能作为重载依据。
D最后一个是常指针,必须在定义时进行初始化。
C数组名在传参数是可以当指针理解。
C(不确定,不知道“函数类型”是什么意思,但感觉d是错的)
A只有宏定义符合“快”的标准。但它并不是函数(其实更合理的答案是内联函数,可是没此选项)
A
B非静态成员从属于对象。静态函数跟类名绑定,于是无法知道该访问哪个对象的成员。
B基类的成员在子类中的可访问性不能大于继承方式修饰限定。
这样不是重载。
函数重载要求函数的参数个数不同或者参数类型不同。
因为调用函数的时候无法确认函数的返回类型,所以仅返回类型不同的函数都可以匹配,这样就造成二义性,所以仅仅是返回类型不同是不能重载的,
比如有
int f(int a)
{
return a+2;
}
float f(int a)
{
return a/30;
}
int main()
{
f(6); //该调用哪个呢?
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)