我倾向于认为我对 C++ 内部结构和内存布局有很好的掌握,但这让我感到困惑。我有以下测试代码:
#include <stdio.h>
struct Foo
{
//Foo() {}
int x;
char y;
};
struct Bar : public Foo
{
char z[3];
};
int main()
{
printf( "Foo: %u Bar: %u\n", (unsigned)sizeof( Foo ), (unsigned)sizeof( Bar ) );
}
输出是合理的:
食物:8 酒吧:12
然而,这是非常奇怪的部分,如果我取消注释 Foo() 上的简单默认构造函数,则 sizeof( Bar ) 会发生变化!添加一个ctor怎么可能改变这些类的内存布局呢?
食物:8 酒吧:8
使用gcc-7.2编译
GCC 遵循用于 C++ 的 Itanium ABI,它防止使用 POD 的尾部填充来存储派生类数据成员。
添加用户提供的构造函数意味着Foo
不再是 POD,因此该限制不适用于Bar
.
看到这个问题有关 ABI 的更多详细信息。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)