基类指针和派生类指针

派生类对象也“是”基类对象,但两者不同。

派生类对象可以当做基类对象,这是因为派生类包含基类的所有成员。

但是基类对象无法被当做成派生类对象,因为派生类可能具有只有派生类才有的成员。

所以,将派生类指针指向基类对象的时候要进行显示的强制转换,否则会使基类对象中的派生类成员成为未定义的。

总结:基类指针和派生类指针指向基类对象和派生类对象的4中方法:

1.  基类指针指向基类对象。(正常使用)
2.  派生类指针指向派生类对象。(正常使用,不管是不是虚函数,调用的都是派生类的函数)
3.  基类指针指向派生类对象是安全的,因为派生类对象“是”它的基类的对象。(多态的体现,虚函数的话调用的是派生类的,非虚函数的话调用的是基类的)
       但是要注意的是,这个指针只能用来调用基类的成员函数。如果试图通过基类指针调用派生类才有的成员函数,则编译器会报错。
       为了避免这种错误,必须将基类指针强制转化为派生类指针。然后派生类指针可以用来调用派生类的功能。这称为向下强制类型转换,这是一种潜在的危险操作。
      注意:如果在基类和派生来中定义了虚函数(通过继承和重写),并同过基类指针在派生类对象上调用这个虚函数,则实际调用的是这个函数的派生类版本。
4.  将派生类指针指向基类对象,会产生编译错误。“是”关系只适用于从派生类到它的直接(或间接)基类,反过来不行。(一般不要这么用)
       基类对象并不包含派生类才有的成员,这些成员只能通过派生类指针调用。

基类与派生类的指针和成员函数调用原理
1.如果以一个基础类指针指向一个衍生类对象(派生类对象),那么经由该指针只能访问基础类定义的函数(静态联编)

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

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

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

猜你喜欢

转载自blog.csdn.net/ytusdc/article/details/85845803
今日推荐