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

在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
微信扫一扫
支付宝扫一扫