前言:如果不想看论证,可以直接点击总结,跳转到最后
目录
总结
1、使用重载函数时,如果数据类型不匹配,C++尝试使用类型转换与形参进行匹配,如果转换后有多个函数能匹配上,编译器将报错;
论证如下:
#include <iostream>
using namespace std;
void show(short no, string message)
{
cout << "short 亲爱的" << no << "号:" << message << endl;
}
void show(long no, string message)
{
cout << "long 亲爱的" << no << "号:" << message << endl;
}
void show(double no, string message)
{
cout << "double 亲爱的" << no << "号:" << message << endl;
}
int main()
{
short a = 10;
show(a,"我喜欢你");
long b = 10;
show(b,"我喜欢你");
double c = 10;
show(c,"我喜欢你");
return 0;
}
运行:
各自都调用了自己对应的函数,没有问题;
我们改一下,把long和double的重载函数注释掉:
我们定义一个double的变量,看他是否会使用short的show输出:
成功输出了,没有问题,只不过编译器提示了,double转成short可能会确实精度,不管他
如果我们定义short的变量,调用double的函数呢?
也没有问题,我们发现了编译器会帮我们隐士转换;
那么如果我们定义short变量,放开long和double的函数,那么short变量会调用哪一个呢?
直接报错,显示有多个重载函数;
观点1论证成功!
2、引用可以作为函数重载的条件,但是,调用重载函数的时候,如果实参是变量,编译器将形参类型的本身和类型引用视为同意特征;
论证如下:
#include <iostream>
using namespace std;
void show(long no, string message)
{
cout << "long 亲爱的" << no << "号:" << message << endl;
}
void show(long& no, string message)
{
cout << "long 亲爱的" << no << "号:" << message << endl;
}
int main()
{
long c = 10;
show(c, "我喜欢你");
return 0;
}
调用函数时,我们先传入变量,运行一下:
无法运行,他说函数有多个重载;因为long和long&都能操作变量c;
如果我们传入常量呢?
成功的调用了long,因为不能对常量进行引用;
观点2论证结束!
3、如果重载函数有默认参数,调用函数时,可能导致匹配失败;
论证如下:
观点3论证结束!
4、const不能作为函数重载的特征;
论证如下:
观点4论证结束!
5、返回值类型不同不能作为函数重载的特征;
论证如下:
观点5论证结束!
总结
1、使用重载函数时,如果数据类型不匹配,C++尝试使用类型转换与形参进行匹配,如果转换后有多个函数能匹配上,编译器将报错;
2、引用可以作为函数重载的条件,但是,调用重载函数的时候,如果实参是变量,编译器将形参类型的本身和类型引用视为同意特征;
3、如果重载函数有默认参数,调用函数时,可能导致匹配失败;
4、const不能作为函数重载的特征;
5、返回值类型不同不能作为函数重载的特征;