重载和覆盖

本文详细解释了面向对象编程中的两个重要概念:重载和覆盖。重载发生在同一类内的同名函数但参数不同,而覆盖则涉及派生类与基类间同名且参数相同的函数,且基类函数需声明为虚函数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

重载:
(1)相同的范围/在同一个类中
(2)函数名字相同
(3)参数不同
(4)virtual 关键字可有可无。
覆盖
(1)不同的范围(分别位于派生类与基类);
(2)函数名字相同
(3)参数相同
(4)基类函数必须有virtual 关键字
### 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、付费专栏及课程。

余额充值