虚基类表相对于虚函数表要稍微难理解些,故单独提出来。

  虚函数表是在对象生成时插入一个虚函数指针,指向虚函数表,这个表中所列就是虚函数。

  虚基类表原理与虚函数表类似,不过虚基类表的内容有所不同。表的第一项表示派生类对象指针相对于虚基类表指针的偏移,从第二项开始表示各个基类地址相对于虚基类表指针的偏移。

  程序

#include <cstdio>

class A
{
public:
int a;
int aa;
virtual void vfuna(){};
}; class B
{
public:
int b;
int bb;
virtual void vfunb(){};
}; class C: virtual public A,virtual public B
{
public:
int c;
int cc;
void vfuna(){};
}; int main(int argc, char** argv)
{
printf("%d\n", sizeof(C)); C c;
c.a = 0xaaaaaaaa;
c.aa = 0xbbbbbbbb;
c.b = 0xdddddddd;
c.bb = 0xeeeeeeee;
c.c = 0x11111111;
c.cc = 0x22222222;
C* pc = &c;
printf("%08x\n", pc);
}

  windows输出:

36
0034f834

  查看对象c内存0x34f834:

0034F834 60 
0034F835 57 
0034F836 1D 00 11 11 11 
0034F83B 11 22  
0034F83D 22 22  
0034F83F 22 58 57  
0034F842 1D 00 AA AA AA  
0034F847 AA 
0034F848 BB BB BB BB 4C 
0034F84D 57 
0034F84E 1D 00 DD DD DD 
0034F853 DD EE
0034F855 EE
0034F856 EE  
0034F857 EE

  查看虚基类表0x001d5760:

C::`vbtable':
001D5760 00 00 add byte ptr [eax],al
001D5762 00 00 add byte ptr [eax],al
001D5764 0C 00 or al,0
001D5766 00 00 add byte ptr [eax],al
001D5768 18 00 sbb byte ptr [eax],al
001D576A 00 00 add byte ptr [eax],al
001D576C 00 00 add byte ptr [eax],al
001D576E 00 00 add byte ptr [eax],al

  得派生类对象指针相对于虚基类表指针的偏移0,基类A地址相对于虚基类表指针的偏移12,基类B地址相对于虚基类表指针的偏移24。查看偏移12位内容为0x001d5758。其指向地址内容:

C::`vftable':
001D5758 91 xchg eax,ecx
001D5759 10 1D 00 00 00 00 adc byte ptr ds:[0],bl
001D575F 00 00 add byte ptr [eax],al

C::vfuna:
001D1091 E9 AA 05 00 00 jmp C::vfuna (1D1640h)

  偏移24位内容为0x0014574c,其指向地址内容为:

C::`vftable':
001D574C 0A 10 or dl,byte ptr [eax]
001D574E 1D 00 00 00 00 sbb eax,0
001D5753 00 F8 add al,bh

B::vfunb:
001D100A E9 F1 05 00 00 jmp B::vfunb (1D1600h)

  验证一个为虚基类A内容,一个为虚基类B内容。

【c++内存分布系列】虚基类表的更多相关文章

  1. C++ 虚继承实现原理(虚基类表指针与虚基类表)

    虚继承和虚函数是完全无相关的两个概念. 虚继承是解决C++多重继承问题的一种手段,从不同途径继承来的同一基类,会在子类中存在多份拷贝.这将存在两个问题:其一,浪费存储空间:第二,存在二义性问题,通常可 ...

  2. C++ 虚基类表指针字节对齐

    下面博客转载自别人的,我也是被这个问题坑了快两天了,关于各种虚基类,虚继承,虚函数以及数据成员等引发的一系列内存对齐的问题再次详细描述 先看下面这片代码.在这里我使用了一个空类K,不要被这个东西所迷惑 ...

  3. c++ 虚函数多态、纯虚函数、虚函数表指针、虚基类表指针详解

    静态多态.动态多态 静态多态:程序在编译阶段就可以确定调用哪个函数.这种情况叫做静态多态.比如重载,编译器根据传递给函数的参数和函数名决定具体要使用哪一个函数.动态多态:在运行期间才可以确定最终调用的 ...

  4. C++中虚基类在派生类中的内存布局

    今天重温C++的知识,当看到虚基类这点的时候,那时候也没有太过追究,就是知道虚基类是消除了类继承之间的二义性问题而已,可是很是好奇,它是怎么消除的,内存布局是怎么分配的呢?于是就深入研究了一下,具体的 ...

  5. c/c++: c++继承 内存分布 虚表 虚指针 (转)

    http://www.cnblogs.com/DylanWind/archive/2009/01/12/1373919.html 前部分原创,转载请注明出处,谢谢! class Base  {  pu ...

  6. 【c++内存分布系列】单继承

    父类包括成员函数.静态函数.静态方法,子类包括成员函数.静态函数.静态方法的情况与一个类时完全一致,这里就不做分析了.子类单独包含虚函数时继承无关,也不做分析了. 一.父类子类都为空 #include ...

  7. RTTI、虚函数和虚基类的实现方式、开销分析及使用指导(虚函数的开销很小,就2次操作而已)

    白杨 http://baiy.cn “在正确的场合使用恰当的特性” 对称职的C++程序员来说是一个基本标准.想要做到这点,首先要了解语言中每个特性的实现方式及其开销.本文主要讨论相对于传统 C 而言, ...

  8. c++内存分布之虚函数(多继承)

    系列 c++内存分布之虚函数(单一继承) c++内存分布之虚函数(多继承) [本文] 结论 1.虚函数表指针 和 虚函数表 1.1 影响虚函数表指针个数的因素只和派生类的父类个数有关.多一个父类,派生 ...

  9. c++内存分布之虚函数(单一继承)

    系列 c++内存分布之虚函数(单一继承) [本文] c++内存分布之虚函数(多继承) 结论 1.虚函数表指针 和 虚函数表 1.1 影响虚函数表指针个数的因素只和派生类的父类个数有关.多一个父类,派生 ...

随机推荐

  1. 【面试题012】打印1到最大的n位数

    [面试题012]打印1到最大的n位数  大数问题 字符串中的每一个字符都是‘0’到‘9’之间的某一个字符,用来表示数字中的一位,因为数字最大是n位的,因此我们需要一个长度为n+1的字符串,字符串的最后 ...

  2. SSH Tunneling Explained

    转载: http://chamibuddhika.wordpress.com/2012/03/21/ssh-tunnelling-explained/ March 21, 2012 by Buddhi ...

  3. java如何得到GET和POST请求URL和参数列表

    转载:http://blog.csdn.net/yaerfeng/article/details/18942739 在servlet中GET请求可以通过HttpServletRequest的getRe ...

  4. HorseCome

    紫气东来,祝福也随之而来,喜鹊登梅,福禄也登上眉梢,马年将至,喜庆将萦绕身旁,在这个美好的日子送上我最真挚的祝福,祝身体安康. 春晓,春晓,处处绿杨芳草.山山水水,欢欢笑笑,共祝六合同春,步步登高!

  5. 协同滤波 Collaborative filtering 《推荐系统实践》 第二章

    利用用户行为数据 简介: 用户在网站上最简单存在形式就是日志. 原始日志(raw log)------>会话日志(session log)-->展示日志或点击日志 用户行一般分为两种: 1 ...

  6. ios中addtarget的用法

    1.addtarget 的.部分使用事件没有直接的操作方式,需要进行调用.就要用addTarget. - (void)setupCustomView { self.customView = [[CHV ...

  7. C结构体之位域(位段)

    C结构体之位域(位段) 有些信息在存储时,并不需要占用一个完整的字节, 而只需占几个或一个二进制位.例如在存放一个开关量时,只有0和1 两种状态, 用一位二进位即可.为了节省存储空间,并使处理简便,C ...

  8. Android自动化测试之Monkeyrunner从零开始(三)

    转自http://www.51testing.com/html/81/22381-854342.html 时光过得太快了,一晃离上一篇monkeyrunner系列的博客已经一年多了.这一年多时间经历了 ...

  9. SGU 275 To xor or not to xor (高斯消元)

    题目链接 题意:有n个数,范围是[0, 10^18],n最大为100,找出若干个数使它们异或的值最大并输出这个最大值. 分析: 一道高斯消元的好题/ 我们把每个数用二进制表示,要使得最后的异或值最大, ...

  10. poj 1703 Find them, Catch them(并查集)

    题目:http://poj.org/problem?id=1703 题意:一个地方有两个帮派, 每个罪犯只属于其中一个帮派,D 后输入的是两个人属于不同的帮派, A后询问 两个人是否属于 同一个帮派. ...