RELATEED CONSULTING
相关咨询
选择下列产品马上在线沟通
服务时间:8:30-17:00
你可能遇到了下面的问题
关闭右侧工具栏

新闻中心

这里有您想知道的互联网营销解决方案
菱形虚拟继承&虚函数表&对象模型

菱形继承:

成都创新互联公司是一家网站设计公司,集创意、互联网应用、软件技术为一体的创意网站建设服务商,主营产品:成都响应式网站建设公司高端网站设计营销型网站。我们专注企业品牌在网站中的整体树立,网络互动的体验,以及在手机等移动端的优质呈现。网站设计制作、成都网站设计、移动互联产品、网络运营、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()就被覆盖了。小伙伴们懂了吗?菱形虚拟继承&虚函数表&对象模型


标题名称:菱形虚拟继承&虚函数表&对象模型
URL链接:http://scyingshan.cn/article/pihhcd.html