如果同一作用域的几个函数名字相同但形参列表不同,我们称之为重载(overloaded)函数
编译器会根据传递的实参类型推断想的是哪个函数
Note:main函数不能重载
定义重载函数
Record lookup(const Account&); // 根据Account查找
Record lookup(const Phone&);
Record lookup(const Name&);
Account account;
Phone phone;
Record r1 =lookup(account);
Record r2 =lookup(phone);
三个函数各不相同,根据实参确定调用哪一个
判断两个形参的类型是否相异
重载和const形参
对拥有一个顶层const和没有顶层const的形参是不区分的
重载操作类似的函数
Const_cast和重载
string &shorterString(string &s1,string &s2)
{
auto &r = shorterString(const_cast<const string&>(s1),const_cast<const string&>(s2));
return const_cast<string>(r);
}
实参不是常量时,得到普通的引用
调用函数的重载
调用函数重载有三种可能
- 编译器找到一个与实参最佳匹配(best match)的函数,并生成调用该函数的代码
- 找不到任何一个与调用的实参匹配,此时编译器发出无匹配的错误
- 有多于一个函数可以匹配,但是每一个都不是明显的最佳选择,也会报错,称为二义性调用(ambiguous call)
6.4.1 重载与作用域
warning:一般来说,将函数声明置于局部作用域内不是一个明确的选择。但是为了说明暂时违反这一原则。
内层作用域中声明名字,它将隐藏外层作用域中声明的同名实体。
Note:在C++中,名字查找发生在类型检查之前
函数放在同一作作用域中式不同于不同作用域的重载的形式