对象内存布局 (1)

本文探讨了C++中当基类含有虚函数而派生类未重写时的内存布局情况。通过具体示例代码,展示了如何利用虚函数指针遍历并调用所有虚函数,并附上了编译后的运行结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

内容概要:

满足下面2个条件时,

1. 父类有虚函数,子类无虚函数(即无虚函数重写或无虚函数覆盖)

2. 非虚继承

类对象之内存布局

前述相关内容参考:

1. http://blog.youkuaiyun.com/pathuang68/archive/2009/04/20/4096088.aspx

2. http://blog.youkuaiyun.com/pathuang68/archive/2009/04/21/4096429.aspx

3. http://blog.youkuaiyun.com/pathuang68/archive/2009/04/21/4096521.aspx

Base类中有两个虚函数vfBase_1()、vfBase_2()和一个整形成员变量m_base, Derived类中有一个整形成员变量m_derived,二者的关系如下:

代码如下:

#include <iostream>

using namespace std;

class Base

{

public:

int m_base;

inline virtual void vfBase_1()

{

cout << "This is in Base::vfBase_1()" << endl;

}

inline virtual void vfBase_2()

{

cout << "This is in Base::vfBase_2()" << endl;

}

};

class Derived : public Base

{

public:

int m_derived;

};

typedef void (*VFun)(void);

// 改为template形式,因为不能确定传进来的参数是Base类型的指针还是Derived类型的指针

template<typename T>

VFun virtualFunctionPointer(T* b, int i)

{

return (VFun)(*((int*)(*(int*)b) + i));

}

int main(void)

{

Derived d;

cout << "The size of Base object = /t" << sizeof(Derived) << endl;

cout << endl;

int i = 0;

while(virtualFunctionPointer(&d, i))

{

VFun pVF = virtualFunctionPointer(&d, i++);

pVF();

}

return 0;

}

运行结果如下:

Derived对象的memory layout图解如下:

后篇:http://blog.youkuaiyun.com/pathuang68/archive/2009/04/23/4101977.aspx

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值