C++继承中的重载、覆盖和隐藏

本文阐述了函数重载的概念及特点,强调了重载必须在同一类中实现,并通过实例展示了如何实现重载和覆盖。重点区分了重载与继承中的覆盖在C++中的区别,解释了它们各自的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

重载(overload):   必须在一个域中,函数名称相同但是函数参数不同,重载的作用就是同一个函数有不同的行为,因此不是在一个域中的函数是无法构成重载的,这个是重载的重要特征   必须在一个域中,而继承明显是在两个类。 class A { public: virtual void doSth(int a){ printf("I am .../n");} overload virtual void doSth(){ printf("I am A/n");} }; class B:public A { public: void doSth(){ printf("I am B/n");} 派生类中的doSth把基类中的doSth隐藏了 }; main() { B BDEMO; BDEMO.doSth(); printf("test/n"); } 相同的函数名的函数,在基类和派生类中的关系只能是覆盖或者隐藏。 覆盖(override): 如果基类中的函数和派生类中的两个名字一样的函数f   满足下面的两个条件   (a)在基类中函数声明的时候有virtual关键字   (b)基类CA中的函数和派生类CB中的函数一模一样,函数名,参数,返回类型都一样。   那么这就是叫做覆盖(override),这也就是虚函数,多态的性质   其他的情况只要名字一样,不满足上面覆盖的条件,就是隐藏了。 隐藏(hide):   指的是派生类的成员函数隐藏了基类函数的成员函数.隐藏一词可以这么理解:在调用一个类的成员函数的时候,编译器会沿着类的继承链逐级的向上查找函数的定义,如果找到了那么就停止查找了,所以如果一个派生类和一个基类都有同一个同名(暂且不论参数是否相同)的函数,而编译器最终选择了在派生类中的函数,那么我们就说这个派生类的成员函数"隐藏"了基类的成员函数,也就是说它阻止了编译器继续向上查找函数的定义
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值