【整理】基类与派生类的指针和成员函数调用原理

基类与派生类的指针和成员函数调用原理

1.如果以一个基础类指针指向一个衍生类对象(派生类对象),那么经由该指针只能访问基础类定义的函数(静态联翩)

2.如果以一个衍生类指针指向一个基础类对象,必须先做强制转型动作(explicit cast),这种做法很危险,也不符合生活习惯,在程序设计上也会给程序员带来困扰。(一般不会这么去定义)

3.如果基础类和衍生类定义了相同名称的成员函数(非虚函数),那么通过对象指针调用成员函数时,到底调用哪个函数要根据指针的类型(基类指针or派生类指针)来确定,而不是根据指针实际指向的对象类型确定。

4.如果基础类和衍生类定义了相同名称的成员函数(虚函数virtual),那么通过对象指针调用成员函数时,到底调用哪个函数要根据指针实际指向的对象类型(基类对象or派生类对象)来确定,而不是根据指针的类型确定。

5.纯虚拟函数:
  virtual void myfunc ( ) =0;

5.1纯虚拟函数不许定义其具体动作,它的存在只是为了在衍生类中被重新定义。只要是拥有纯虚拟函数的类,就是抽象类,它们是不能够被实例化的(只能被继承)。如果一个继承类没有改写父类中的纯虚函数,那么他也是抽象类,也不能被实例化。

5.2抽象类不能被实例化,不过我们可以拥有指向抽象类的指针,以便于操纵各个衍生类。

5.3虚拟函数衍生下去仍然是虚拟函数,而且还可以省略掉关键字“virtual”。

——如有不对的地方,非常欢迎给予指导!

原文地址:https://www.cnblogs.com/engraver-lxw/p/7581841.html