对含有virtual function的class求sizeof

本文通过一个C++示例程序介绍了虚函数表的工作原理,包括不同类的虚函数如何组织,以及多重继承中虚函数表的实现方式。通过断点调试展示了不同类实例大小的变化及其原因。

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

#include <iostream>
using namespace std;

class A
{
public:
	virtual void func_1() {}
	virtual void func_2() {}
	virtual ~A() {}
};

class B
{
public:
	virtual void func_3() {}
};

class C : public B
{
public:
	virtual void func_3() {}// 覆盖
	virtual void func_4() {}
};

class D : public A, public B
{
public:
	virtual void func_1() {}
	virtual void func_5() {}
};

int main()
{
	// 断点调试查看虚表
	A a;
	B b;
	C c;
	D d;

	
	cout << "sizeof(A) = " << sizeof(A) << endl;//sizeof(A) = 4,因为无论有多少虚函数,A实例只有一个指向虚表的指针
	cout << "sizeof(B) = " << sizeof(B) << endl;//sizeof(A) = 4,理由同上
	cout << "sizeof(C) = " << sizeof(C) << endl;//sizeof(A) = 4,单一继承
	cout << "sizeof(D) = " << sizeof(D) << endl;//sizeof(A) = 8,多重继承,D有两张虚表,也有两个执行项虚表的指针,所以为8
	cin.get();
}


断点调试时内存模型:



exec::task<void> net_block_extra_const_process() try { DEBUG_TIME_TRACE_SCOPE(utils::TRACE_TIER::INNER_PROCESS, __FUNCTION__); DEBUG_CAM_TRACE_ASYNC_SCOPE(__FUNCTION__, utils::DEFAULT_TRACE_ID); auto batch_num = fx::capn_algo_settings(e_)->getNet().getGenerateCfg().getPatchNum(); if (!net_cfg_params_.hasModelName()) { throw invalid_params{EXCEPTION_POINT}; } auto &extra_consts = rpr_.extra_net_params->extra_consts; if (patch_buffers_->extra_const_buffer == nullptr) { CAM_LOG_WARNING(__FUNCTION__ << " extra_const_buffer is null"); throw invalid_params{EXCEPTION_POINT}; } if (rpr_.extra_net_params->is_not_extra_const == false) { auto size = extra_consts.size(); if (batch_num <= 0 || size == 0) { throw invalid_params{EXCEPTION_POINT}; } if (net_cfg_params_.getIsQualcommFp16() == false) { auto ecb = static_cast<__fp16 *>(patch_buffers_->extra_const_buffer->getAddress()); errno_t err = memcpy_s(ecb, patch_buffers_->extra_const_buffer->getSize(), extra_consts.data(), size * sizeof(airaw::pre_processing::psf_pred::extrac_const)); if (err != EOK) { CAM_LOG_WARNING(__PRETTY_FUNCTION__ << " memcpy extraConst to buff failed"); throw securec_failed{EXCEPTION_POINT}; } } else { auto ecb = static_cast<float *>(patch_buffers_->extra_const_buffer->getAddress()); for (int i = 0; i < extra_consts.size(); i++) { ecb[i] = extra_consts[i].normal; } } } fx::ops::flush_cc(patch_buffers_->extra_const_buffer); CAM_LOG_INFO(__FUNCTION__ << " extra const success"); co_return; } CATCH_AND_NEST()代码函数深度为6,请降低函数深度并进行详细说明
最新发布
04-02
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值