函数覆盖发生在父类与子类之间,其函数名、参数类型、返回值类型必须同父类中的相对应被覆盖的函数严格一致,(只有一种情况下返回值可以不一致,那就是返回自己类的引用或者指针的时候)覆盖函数和被覆盖函数只有
函数体不同,当派生类对象调用子类中该同名函数时会自动调用子类中的覆盖版本,而不是父类中的被
覆盖函数版本,这种机制就叫做函数覆盖。
好了有了对象的类型就好办了。当你用这个对象(或者是
指针、引用)去调用函数时,
2:但是当我们用引用或
指针形式时,有个问题是区别指针(引用)的类型和指针(引用)所指实体对象的类型。
A:你用
指针来调用某函数,若函数是非
虚函数,非虚函数是
静态编译的(即编译时刻确定的)。也就是说他不会去
虚函数表找这个函数(因为不是虚函数),因 此调用的是
指针类型的那个类的相关函数。即使派生类有这个函数(这是实际编程时的大忌!!!)。这就是 你的void FunctionA() const ;
B: 当你用这个
指针去调用一个
虚函数时,他就到
虚函数表中,找这个名字的函数,从指针所指对象的类型(即派生类)依次向父类走,直到遇到第一个与次匹配的函数名。
2。在将父类对象的
指针指向子类对象的时候 Father* father = new Child;
3。如果直接声明子类对象,Child child;则无论child.FunctionA()还是 child.FunctionB(),执行的都是Child中的实现。