4 虚函数用法

分析下列程序:

#include<iostream>
#include<string.h>
using namespace std;
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

分析:

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

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


1.重载:重载从overload翻译过来,是指同一可访问区内被声明的几个具有不同参数列(参数的类型,个数,顺序不同)的同名函数,根据参数列表确定调用哪个函数,重载不关心函数返回类型。

2.隐藏:隐藏是指派生类的函数屏蔽了与其同名的基类函数。注意只要同名函数,不管参数列表是否相同,基类函数都会被隐藏。

3.重写:重写翻译自override,也翻译成覆盖(更好一点),是指派生类中存在重新定义的函数。其函数名,参数列表,返回值类型,所有都必须同基类中被重写的函数一致。只有函数体不同(花括号内),派生类调用时会调用派生类的重写函数,不会调用被重写函数。重写的基类中被重写的函数必须有virtual修饰。

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

动态绑定只有在通过指针或引用调用虚函数时才会发生。

虚函数在构造函数里面与普通函数一样,失去了多态性,但是一般在构造函数里面不调用虚函数。

拥抱明天! 不给自己做枷锁去限制自己。 别让时代的悲哀,成为你人生的悲哀。
原文地址:https://www.cnblogs.com/dd2hm/p/7227564.html