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)匹配第二个。

函数重写(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;引入基类的所有重载版本。

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