多重继承下的virtual table
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
1.1.1.多重继承下的虚成员函数
0001 class Base1
0002 {
0003 public :
0004 Base1();
0005 virtual ~Base1();
0006 virtual void speakClearly();
0007 virtual Base1 *clone() const;
0008 protected :
0009 float data_Base1;
0010 };
0011 class Base2
0012 {
0013 public :
0014 Base2();
0015 virtual ~Base2();
0016 virtual void mumble();
0017 virtual Base2 *clone() const;
0018 protected :
0019 float data_Base2;
0020 };
0021 class Derived : public Base1, public Base2
0022 {
0023 public :
0024 Dervied();
0025 virtual ~Dervied();
0026 virtual Dervied *clone() const;
0027 protected :
0028 float data_Dervied;
0029 };
Dervied支持虚函数(virtual function)的难度在于Base2 Subobject,有三个问题待解决:1)析构函数
2)Base2::mumble();
3)一组clone函数
多重继承下,一个派生类产生n-1个额外的虚函数表,用于表示基类(上一层)的数目,单一继承也可以看作特殊的多重继承。对象模型如下所示:
Base1 object Base1 Virtual Function Table
Base2 object Base2 Virtual Function Table
Derived Virtual Function Table(Shared with Base1) Derived object
Base2_Derived Virtual Function Table
当一个Derived 对象指定给一个Base1或Derived 指针,被处理的virtual Table 为主要表格vtbl_Derived 指针,而将一个Derived 对象指派给一个Base2指针,被处理的virtual Table 是次要表格vtbl_Base2_Derived 。
有三种情况后继的Base Class 会影响virtual function 的支持:
1) 通过后继的Base Class 指针调用Derived Class virtual function 。也就是前述1)
Base2 *pb2 = new Derived;
delete pb2;
//C++伪代码
Derived *tmp = new Derived;
Base2 *pb2 = temp ? temp + sizeof(Base1) : 0;
(*pb2->vptr[1])(pb2 - sizeof(Base1));
2)通过Dervied class 指针,调用后继的Base class中的继承而来的virtual function。也就是前述2)
Derived *pb = new Derived;
pd->mumble();
//C++伪代码
Derived *pd = new Derived;
(*pd->vptr[2])();
3)发生在语言扩充性质下,允许一个virtual function 的返回值类型有所变化,可能是Base type也可能是publicly derived type。也就是前述3)
Base2 *pb1 = new Derived;
Base2 *pb2 = pb1->Clone();
//C++伪代码
Derived *tmp = new Derived;
Base2 *pb1 = temp ? temp + sizeof(Base1) : 0;
Derived *temp = (*pb1->vptr[3])();
Base2 *pb2 = temp ? temp + sizeof(Base1) : 0;