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

在C++中,函数重载、重写和隐藏是三个容易混淆但非常关键的概念,它们分别在不同的场景下影响函数的调用行为。理解这三者有助于掌握C++的多态性和类继承机制。
函数重载发生在同一个作用域内,多个函数具有相同的名称但参数列表不同(参数个数、类型或顺序不同)。编译器根据调用时传入的实参来决定调用哪个版本的函数。
注意:返回类型不同不足以构成重载,必须参数列表有差异。
示例:
void print(int a) { }
void print(double a) { }
void print(const char* str) { }
这三个print函数构成了重载。调用print(5)会匹配第一个,print(3.14)匹配第二个。
立即学习“C++免费学习笔记(深入)”;
函数重写发生在继承体系中,派生类中定义了一个与基类虚函数同名、同参数列表、同返回类型的函数,并且基类中的函数被声明为virtual。此时,通过基类指针或引用调用该函数时,会动态绑定到派生类的实现,实现运行时多态。
重写的关键在于“虚函数”和“动态绑定”。
示例:
class Base {
   public:
      virtual void show() { cout << "Base"; }
};
class Derived : public Base {
   public:
      void show() override { cout << "Derived"; } // 重写基类虚函数
};
当使用Base* ptr = new Derived(); ptr->show();时,输出“Derived”,这就是多态的体现。
函数隐藏是指在派生类中定义了一个与基类同名的函数(无论是否是虚函数,参数是否相同),此时基类中所有同名函数都会被隐藏,即使参数列表不同也不会形成重载。
隐藏不关心是否为虚函数,只要名字相同就可能发生。
示例:
class Base {
   public:
      void func() { cout << "Base::func()"; }
      void func(int x) { cout << "Base::func(int)"; }
};
class Derived : public Base {
   public:
      void func(double x) { cout << "Derived::func(double)"; }
};
在Derived中定义了func(double),它会隐藏基类中所有的func函数。即使你想调用func()或func(5),也不能直接访问,除非显式使用Base::func()。
若想恢复基类函数的可见性,可以在派生类中使用using Base::func;引入基类的所有重载版本。
基本上就这些。重载看参数,重写靠虚函数实现多态,隐藏则是名字遮蔽。理清作用域和继承关系,就能准确判断函数行为。
以上就是c++++中什么是函数重载、重写和隐藏_c++多态性与函数行为解析的详细内容,更多请关注php中文网其它相关文章!
 
                        
                        c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
 
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号