C++重载、重写(覆盖)和隐藏

java中只有重载和覆盖,由于c++有virtual关键字,于是就多了个隐藏。

重载的特征:同一个作用域中(比如在同一个类),函数名相同,参数不同,virtual可有可无。
覆盖的特征:在两个类(基类和派生类),函数名和参数都相同,且必须有virtual关键字。
隐藏的特征:基类函数名和派生类函数名相同参数不同,且不管是否有关键字。或函数名、参数均相同,但基类函数没有virtual(有的话就是覆盖)不能覆盖而只能隐藏基类非虚函数。

参考:《高质量C++编程指南》

### C++重写重载覆盖的概念及用法 #### 函数重载 (Overloading) 函数重载是指在同一作用域内定义多个同名函数,只要参数列表不同即可。编译器会根据调用时传递的实际参数来决定具体调用哪个版本的函数。 ```cpp class Example { public: void func(int a); // 版本一 void func(double d, int b);// 版本二 }; ``` 注意,返回值类型不作为区分标准的一部分[^1]。 #### 成员函数覆盖 (Hiding) 成员函数覆盖发生在派生类中声明了一个与基类相同名称的方法,即使签名完全不同也会隐藏掉基类中的所有同名方法。如果希望访问被隐藏的方法,则需通过作用域解析运算符 `::` 明确指定要调用的是哪一个版本的方法。 ```cpp class Base { public: virtual void show() { cout << "Base class"; } }; class Derived : public Base { public: void show(int i) { cout << "Derived class with parameter"; } // 隐藏了show() }; ``` 这里需要注意,在子类中重新定义父类已有的非虚函数将会完全遮蔽原有实现,而不是扩展其功能[^3]。 #### 方法重写 (Override) 当一个派生类拥有与其基类相同的原型(即具有相同的形参表)的虚拟成员函数时,就构成了对该成员函数重写。此时,派生于该类型的对象可以表现出不同的行为模式——这就是所谓的运行时期间动态绑定或多态性的体现之一。 ```cpp #include <iostream> using namespace std; class Animal { public: virtual void sound() const = 0; // 抽象类 }; class Dog : public Animal { public: void sound() const override { cout << "Woof!"; } // 重写了sound() }; ``` 上述例子展示了如何利用纯虚函数创建接口,并由具体的子类提供实际的行为逻辑[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值