C/C++学习(1)面向对象的多态性问题、虚函数调用

题目来源:点击打开链接

以下代码的运行结果为:
class Base {
public:
Base() {echo();}
virtual void echo() {printf(“Base”);}
};
  
class Derived:public Base {
public:
Derived() {echo();}
virtual void echo() {printf(“Derived”);}
};
  
int main() {
Base* base = new Derived();
base->echo();
return 0;
}

答案:
Base
Derived
Derived

分析思路:要构造Derived必须先构造Base,然后再调用Derived的echo。


参考链接: 点击打开链接


以下图示更能描述默认继承和虚拟继承的区别. 

默认继承: 

           base             base 
              |               | 
              |               | 
             Mid1             Mid2 
              |               | 
                      | 
                     Child 

存在两个类体系是出错的原因. 


虚拟继承: 

                     base 
                      | 
              |                 | 
              Mid1              Mid2 
              |                 | 
                      | 
                     Child 

使用虚拟继承将类的体系整合起来. 


————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————


首先声明Base类型的指针指向实际类型为Derived的对象,先调用基类构造函数,再调用派生类构造函数。输出Base, Derived.

base->echo(); 指针是Base类型,但是因为有关键词 virtual,所以不是隐藏而是重写.调用的是Derived的方法,输出Derived。

1.重载:重载从overload翻译过来,是指同一可访问区内被声明的几个具有不同参数列(参数的类型,个数,顺序不同)的同名函数,根据参数列表确定调用哪个函数,重载不关心函数返回类型。
2.隐藏:隐藏是指派生类的函数屏蔽了与其同名的基类函数。注意只要同名函数,不管参数列表是否相同,基类函数都会被隐藏。
3.重写:重写翻译自override,也翻译成覆盖(更好一点),是指派生类中存在重新定义的函数。其函数名,参数列表,返回值类型,所有都必须同基类中被重写的函数一致。只有函数体不同(花括号内),派生类调用时会调用派生类的重写函数,不会调用被重写函数。重写的基类中被重写的函数必须有virtual修饰。


父类构造函数里不能调用虚函数,因为虚函数是运行时调用确定的,父类对象会调用子类函数,这样会出问题


C++中重载、重写(覆盖)和隐藏的区别

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值