重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
菱形继承:
成都创新互联公司是一家网站设计公司,集创意、互联网应用、软件技术为一体的创意网站建设服务商,主营产品:成都响应式网站建设公司、高端网站设计、营销型网站。我们专注企业品牌在网站中的整体树立,网络互动的体验,以及在手机等移动端的优质呈现。网站设计制作、成都网站设计、移动互联产品、网络运营、VI设计、云产品.运维为核心业务。为用户提供一站式解决方案,我们深知市场的竞争激烈,认真对待每位客户,为客户提供赏析悦目的作品,网站的价值服务。
Assitant的菱形继承对象模型
Assitant中有两份Person成员,存在二义性和数据冗余。
所以我们引出了虚拟继承。
virtual虚继.不会在子类中创建父类成员,但是子类中可以引用,就像指针一样。主要用在菱形继承,也叫钻石继承。
虚拟继承对象模型
class Student : vitrual public Person class Teacher : virtual public Peraon
虚函数表
通过一块连续内存来存储虚函数的地址。这张表解决了继承、虚函数(重写)的
问题。在有虚函数的对象实例中都存在一张虚函数表,虚函数表就像一张地图,指明了实
际应该调用的虚函数。
举例:
typedef void(*PFUN)(); void PrintVT(int p)//打印虚函数表的信息 { PFUN pfun = NULL; int *ptr = (int *)p; cout << "虚表地址->" << ptr << endl; int i = 0; while (ptr[i]) { pfun = (PFUN)ptr[i]; cout << "第" << i << "个虚函数地址-》 " << pfun<<"----"; pfun(); i++; } }
class B { public: virtual void fun1() { cout << "B::fun1()" << endl; } virtual void fun2() { cout << "B::fun2()" << endl; } private: int _b; }; class D :public B { public: virtual void fun1() { cout << "D::fun1()" << endl; } virtual void fun3() { cout << "D::fun3()" << endl; } virtual void fun4() { cout << "D::fun4()" << endl; } private: int _d; }; int main() { D d; B b; PrintVT(*(int *)&d); cout << endl; PrintVT(*(int *)&b); getchar(); return 0; }
其结果如下:
这就是我们所说的虚函数。因为在D里重写的B::fun1();所以D中的fun1()就被覆盖了。小伙伴们懂了吗?