C++重写函数、隐藏函数、重载函数的区别对比

  目录

1.函数重载

        1.1定义

        1.2函数重载的规则:

        1.3函数重载的作用:

2.函数重写:

        2.1定义

        2.2例子: 

3.函数隐藏

        3.1定义

        3.2举个例子:


1.函数重载

        1.1定义

        我们在学类和对象的封装特性时学过一个词叫重载,函数重载,就是函数重载是一种特殊情况,C++允许在同一作用域中声明几个类似的同名函数,这些同名函数的形参列表(参数个数,类型,顺序)必须不同,常用来处理实现功能类似数据类型不同的问题。

案例如下:

void Swap1(int* a, int* b);
void Swap2(float* a, float* b);
void Swap3(char* a, char* b);
void Swap4(double* a, double* b);

这四个Swap函数都是函数重载,同名,但形参列表不同形成的函数。

 

        1.2函数重载的规则:

1.函数名称必须相同。
2.参数列表必须不同(个数不同、类型不同、参数排列顺序不同等)。
3.函数的返回类型可以相同也可以不相同。
4.仅仅返回类型不同不足以成为函数的重载。

        

        1.3函数重载的作用:

      

### C++函数重载重写隐藏区别与用法 #### 1. 函数重载 (Overloading) 函数重载指的是在同一作用域内定义多个具有相同名称但参数列表不同的函数。这里的参数列表不同可以体现在以下几个方面: - 参数的数量不同。 - 参数的类型不同。 - 参数的顺序不同。 需要注意的是,函数的返回值类型不参与区分重载函数[^2]。 以下是函数重载的一个例子: ```cpp #include <iostream> using namespace std; class Example { public: void display(int a) { cout << "Displaying int: " << a << endl; } void display(double a) { cout << "Displaying double: " << a << endl; } }; int main() { Example e; e.display(5); // 调用第一个display e.display(5.5); // 调用第二个display } ``` 运行结果会显示两种类型的变量分别调用了对应的`display`方法[^2]。 --- #### 2. 函数重写 (Override) 函数重写发生在派生类中重新定义基类中的函数时。为了实现动态绑定(即运行时多态),基类中的函数必须声明为 `virtual` 关键字修饰。在 C++11 及之后的标准中,可以在派生类中使用 `override` 来显式标记该函数是对基类虚函数重写[^5]。 重写的条件如下: - 基类中的函数必须是虚函数 (`virtual`)。 - 子类中的函数签名(包括返回类型、函数名以及参数列表)应与基类一致(协变返回类型除外)。 - 如果子类未正确匹配基类的虚函数,则不会触发重写行为,而是创建一个新的独立函数[^3]。 下面是一个简单的示例: ```cpp #include <iostream> using namespace std; class Base { public: virtual void show() { cout << "Base::show" << endl; } }; class Derived : public Base { public: void show() override { cout << "Derived::show" << endl; } // 使用override关键字标明这是重写 }; int main() { Base* obj = new Derived(); obj->show(); // 输出 "Derived::show" delete obj; } ``` 在这个例子中,尽管通过基类指针访问了派生类的对象,但由于实现了虚函数机制,最终调用的是派生类版本的方法[^5]。 --- #### 3. 函数隐藏 (Hiding) 当派生类中存在与基类同名的函数时,无论是否有相同的参数列表,都会隐藏掉基类中的所有同名函数。即使它们有不同的参数列表也不会构成重载关系[^4]。 例如,在以下代码片段里,虽然`Derived`类里的`print()`只有一个无参形式,但它仍然掩盖住了来自`Base`类的所有版本的`print()`: ```cpp #include <iostream> using namespace std; class Base { public: void print() { cout << "Base::print()" << endl; } void print(int i) { cout << "Base::print(" << i << ")" << endl; } }; class Derived : public Base { public: void print() { cout << "Derived::print()" << endl; } }; int main(){ Derived d; d.print(); // 调用 Derived 的 print() // d.print(5); // 错误! Base 类的 print(int) 已经被隐藏 Base& b = static_cast<Base&>(d); b.print(); // 正常工作,因为此时按 Base 对象看待 b.print(5); // 同样正常工作 } ``` 要解决这种问题允许访问被隐藏的成员函数,可以通过作用域解析运算符(`::`)来指定具体想使用的那个版本的函数[^4]: ```cpp d.Base::print(5); // 访问 Base 版本的带参数打印功能 ``` --- ### 总结表格对比 | **特性/类别** | **函数重载** | **函数重写** | **函数隐藏** | |---------------|----------------------------------|---------------------------------------|------------------------------| | 定义位置 | 同一作用域 | 派生类 | 派生类 | | 返回类型影响 | 不影响 | 影响 | 不影响 | | 参数列表要求 | 必须不同 | 必须完全一致 | 可能完全不同 | | 动态绑定支持 | 不涉及 | 支持 | 不支持 | ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

橙予清的zzz~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值