c++中什么是函数重载、重写和隐藏_c++多态性与函数行为解析

函数重载发生在同一作用域,通过参数列表不同实现;重写需继承中虚函数同签名,实现多态;隐藏是派生类同名函数遮蔽基类所有同名函数。

c++中什么是函数重载、重写和隐藏_c++多态性与函数行为解析

在C++中,函数重载、重写和隐藏是三个容易混淆但非常关键的概念,它们分别在不同的场景下影响函数的调用行为。理解这三者有助于掌握C++的多态性和类继承机制。

函数重载(Function Overloading)

函数重载发生在同一个作用域内,多个函数具有相同的名称但参数列表不同(参数个数、类型或顺序不同)。编译器根据调用时传入的实参来决定调用哪个版本的函数。

注意:返回类型不同不足以构成重载,必须参数列表有差异。

示例:

void print(int a) { }
void print(double a) { }
void print(const char* str) { }

这三个print函数构成了重载。调用print(5)会匹配第一个,print(3.14)匹配第二个。

立即学习“C++免费学习笔记(深入)”;

函数重写(Override,也称覆盖)

函数重写发生在继承体系中,派生类中定义了一个与基类虚函数同名、同参数列表、同返回类型的函数,并且基类中的函数被声明为virtual。此时,通过基类指针或引用调用该函数时,会动态绑定到派生类的实现,实现运行时多态。

重写的关键在于“虚函数”和“动态绑定”。

示例:

class Base {
   public:
      virtual void show() { cout };

class Derived : public Base {
   public:
      void show() override { cout };

当使用Base* ptr = new Derived(); ptr->show();时,输出“Derived”,这就是多态的体现。

函数隐藏(Function Hiding)

函数隐藏是指在派生类中定义了一个与基类同名的函数(无论是否是虚函数,参数是否相同),此时基类中所有同名函数都会被隐藏,即使参数列表不同也不会形成重载。

隐藏不关心是否为虚函数,只要名字相同就可能发生。

示例:

class Base {
   public:
      void func() { cout       void func(int x) { cout };

class Derived : public Base {
   public:
      void func(double x) { cout };

Derived中定义了func(double),它会隐藏基类中所有的func函数。即使你想调用func()func(5),也不能直接访问,除非显式使用Base::func()

若想恢复基类函数的可见性,可以在派生类中使用using Base::func;引入基类的所有重载版本。

基本上就这些。重载看参数,重写靠虚函数实现多态,隐藏则是名字遮蔽。理清作用域和继承关系,就能准确判断函数行为。

以上就是c++++中什么是函数重载、重写和隐藏_c++多态性与函数行为解析的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1481928.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 05:56:30
下一篇 2025年12月19日 05:56:40

相关推荐

发表回复

登录后才能评论
关注微信