注:以下操作在VS(2013)的32位平台下完成的,各个平台上可能有些许差异
32位平台和64位平台打印虚表的方式有所不同,可以看 https://blog.youkuaiyun.com/j4ya_/article/details/80176075 最后.
首先完成一段菱形继承:
class A
{
public:
virtual void func1()
{
cout << "A::func1" << endl;
}
virtual void funcA()
{
cout << "A::funcA" << endl;
}
public:
int _a;
};
class B : virtual public A
{
public:
virtual void func1()
{
cout << "B::func1" << endl;
}
virtual void funcB()
{
cout << "B::funcB" << endl;
}
public:
int _b;
};
class C : virtual public A
{
public:
virtual void func1()
{
cout << "C::func1" << endl;
}
virtual void funcC()
{
cout << "C::funcC" << endl;
}
public:
int _c;
};
class D : public B,public C
{
public:
virtual void func1()
{
cout << "D::func1" << endl;
}
virtual void funcD()
{
cout << "D::funcD" << endl;
}
public:
int _d;
};
C++菱形继承下的虚表解析

本文探讨了在C++中菱形继承时对象模型的虚表结构。通过实例展示了虚表指针和虚基表指针如何存储,以及它们在内存中的分布和作用。内容包括虚函数的位置、虚表的查看以及虚基类的偏移量等关键点。
最低0.47元/天 解锁文章
2511





