使用作用域解析符可调用被重写的父类函数,如Base::func();当子类隐藏父类同名函数时,需用using引入父类重载;虚函数中可通过父类名调用实现扩展。

在C++中,当子类重写了父类的同名函数时,如果想在子类中调用父类的该函数,可以通过作用域解析运算符 :: 显式指定调用父类版本。这是最常见且安全的方式。
使用作用域解析符调用父类函数
当子类覆盖了父类的成员函数,仍然可以在子类内部通过 Base::func() 的形式调用父类的实现。
示例代码:
#include using namespace std;class Parent {public: void show() { cout << "Parent's show()" << endl; }};class Child : public Parent {public: void show() { Parent::show(); // 调用父类的 show() cout << "Child's show()" << endl; }};int main() { Child c; c.show(); // 输出:Parent's show() 和 Child's show() return 0;}
处理继承中的同名隐藏问题
如果父类和子类有同名函数,即使参数不同,子类函数也会**隐藏**父类的所有同名函数(不是重载)。此时不能直接调用父类的其他重载版本。
立即学习“C++免费学习笔记(深入)”;
解决方法是在子类中使用 using 声明 引入父类的函数重载集。
示例:
class Parent {public: void func(int x) { cout << "Parent::func(int): " << x << endl; }};class Child : public Parent {public: using Parent::func; // 引入父类所有 func 重载 void func(double x) { cout << "Child::func(double): " << x << endl; }};int main() { Child c; c.func(5); // 可以调用 Parent::func(int) c.func(3.14); // 调用 Child::func(double) return 0;}
虚函数与多态中的调用技巧
对于虚函数,若在子类中需要扩展父类行为,通常做法是先调用父类函数,再添加子类逻辑。
示例:
class Shape {public: virtual void draw() { cout << "Drawing basic shape" << endl; } virtual ~Shape() = default;};class Circle : public Shape {public: void draw() override { Shape::draw(); // 先执行父类逻辑 cout << "Drawing a circle" << endl; }};
这种方式常用于构造初始化、资源清理或日志记录等场景,确保基类逻辑不被遗漏。
基本上就这些。掌握 :: 调用和 using 声明,就能灵活处理C++中父类同名函数的调用问题。不复杂但容易忽略细节。
以上就是c++++中如何调用父类同名函数_c++调用父类同名函数技巧的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1477601.html
微信扫一扫
支付宝扫一扫