一、普通继承
1、先获取到对象a1的地址,通过地址查看内存,如下:
可知内存布局如下:
父类成员变量 |
子类成员变量 |
二、父类含有虚函数
可见内存布局如下:
虚函数表指针 |
父类成员变量 |
子类成员变量 |
三、虚基类
虚继承的情况下,对象a1的大小为12字节,是因为前四字节是虚基表地址(区别于虚函数地址)。
虚基表第二个四字节是虚基表变量的偏移量,
也就是说虚基表地址要偏移8个字节才能找打虚基类的变量
虚基表地址 |
A1成员变量 |
虚基类成员变量 |
四、上述虚继承只是为了分析,实际中不会用,因为没什么意义, 我们需要用的是下面的虚继承
内存模型:
虚基类指针指向最后一个成员 |
A1成员变量 |
虚基类指针指向A2的成员变量 |
A2成员变量 |
C对象成员变量 |
Grand虚基类成员变量 |
所以这里有个this指针偏移的问题。
比如这里c1对象,不管是取Grand成员变量、A1成员变量、本身的成员变量,只需在c1的地址上+偏移即可,
但要取A2的成员变量,要把this指针编程A2对象的地址,再偏移。
看如下例子:
c直接赋给a2,但他俩的地址并不相同。
这是因为A2是第二个继承的类。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)