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

xiaoxiao2021-02-28  139

题目来源:点击打开链接

以下代码的运行结果为: 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++中重载、重写(覆盖)和隐藏的区别

转载请注明原文地址: https://www.6miu.com/read-25504.html

最新回复(0)