C++深度解析 函数重载分析(7)
函数重载(Function Overload)
用同一个函数名定义不同的函数。
当函数名和不同的参数搭配时函数的含义不同。
函数名相同,函数参数不同。
示例程序:
#include <stdio.h>
#include <string.h>
int func(int x)
{
return x;
}
int func(int a, int b)
{
return a + b;
}
int func(const char* s)
{
return strlen(s);
}
int main(int argc, char *argv[])
{
printf("%d\n", func(3)); //int func(int x)
printf("%d\n", func(4, 5)); //int func(int a, int b)
printf("%d\n", func("D.T.Software")); //int func(const char* s)
return 0;
}
结果如下:
函数重载至少满足下面的一个条件
- 参数个数不同
- 参数类型不同
- 参数顺序不同
int func(int a, const char* s)
{
return a;
}
int func(const char* s, int a)
{
return strlen(s);
}
分析:上面两个函数合法的,参数顺序不同,构成重载函数。
函数默认参数 VS 函数重载
示例程序:
#include <stdio.h>
#include <string.h>
int func(int a, int b, int c = 0)
{
return a * b * c;
}
int func(int a, int b)
{
return a + b;
}
int main(int argc, char *argv[])
{
int c = func(1 ,2); //错误的,模糊的。不知道调用哪个函数
return 0;
}
结果如下:
分析:两个func()函数参数个数不一样,构成重载。但是在main()函数里不知道调用谁。
编译器调用重载函数的准则:
- 将所有同名函数作为候选者
- 尝试寻找可行的候选函数
重载函数匹配失败的原因:
- 二义性:最终找到的候选函数不唯一,出现二义性,编译失败。
- 匹配不上:无法匹配所有的同名函数,函数未定义,编译失败。
示例程序:
#include <stdio.h>
#include <string.h>
int func(int a, int b, int c = 0)
{
return a * b * c;
}
int func(int a, int b)
{
return a + b;
}
int main(int argc, char *argv[])
{
int c = func(1); //失败,匹配不上
return 0;
}
结果如下:
分析:找不到匹配的函数。可选的候选者有:int func(int, int, int) 和 int func(int, int)。
函数重载的注意事项
函数重载的本质是相互独立的不同函数。
函数返回值不能作为函数重载的依据!
函数重载是由函数名和参数列表决定的!
示例程序:(函数重载的本质)
#include <stdio.h>
int add(int a, int b) // 函数类型:int(int, int)
{
return a + b;
}
int add(int a, int b, int c) // 函数类型:int(int, int, int)
{
return a + b + c;
}
int main()
{
//函数名是函数的入口地址
//地址不同,两个是不同的函数
//(int(*)(int, int)):函数指针类型
printf("%p\n", (int(*)(int, int))add);//通过强制类型转换,将add名字转换为函数指针
printf("%p\n", (int(*)(int, int, int))add);
return 0;
}
结果如下:
小结:
函数重载是C++中引入的概念
函数重载用于模拟自然语言中的词汇搭配
函数重载使得C++具有更丰富的语义表达能力
函数重载的本质为相互独立的不同函数
C++中通过函数名和函数参数确定函数调用