
在c++中,函数重载允许在同一作用域内定义多个同名函数,只要它们的参数列表不同(参数个数、类型或顺序不同),编译器会根据调用时传入的实参来选择匹配的函数。函数重载不能仅通过返回类型的不同来区分。
1. 参数类型不同实现重载
最常见的方式是让函数的参数类型不同:
void print(int x) { std::cout << "整数: " << x << std::endl; } void print(double x) { std::cout << "浮点数: " << x << std::endl; } void print(const std::string& x) { std::cout << "字符串: " << x << std::endl; }
调用 print(5) 会匹配 int 版本,print(3.14) 匹配 double 版本。
2. 参数个数不同实现重载
函数可以有不同数量的参数:
立即学习“C++免费学习笔记(深入)”;
void show() { std::cout << "无参数版本" << std::endl; } void show(int a) { std::cout << "一个整数: " << a << std::endl; } void show(int a, int b) { std::cout << "两个整数: " << a << ", " << b << std::endl; }
根据传入参数的数量,编译器会选择合适的函数。
3. 参数顺序不同实现重载
即使参数类型相同但顺序不同,也可以构成重载:
void process(char c, int n) { std::cout << "字符和整数: " << c << ", " << n << std::endl; } void process(int n, char c) { std::cout << "整数和字符: " << n << ", " << c << std::endl; }
注意:这种重载容易引起混淆,使用时需谨慎。
4. const 成员函数重载(针对类成员)
在类中,成员函数是否为 const 也可以构成重载:
class Data { int value = 100; public: int& get() { return value; } const int& get() const { return value; } };
非const对象调用非const版本,const对象调用const版本。
函数重载的关键在于编译器在编译期根据实参进行函数解析(名称修饰与匹配)。它不支持仅靠返回类型区分,也不适用于不同作用域中的函数(会被隐藏而非重载)。
基本上就这些,掌握参数差异是核心。


