首先,我知道sizeof取决于机器和编译器的实现。我使用的是Windows 8.1。 x64,gcc 5.3.0。,没有标志传递给编译器 我的大学讲座中有以下代码:
#include <iostream>
class A
{
public:
int a;
int b;
A(){ a = 1; b = 2; }
};
class S1 : public A {
public:
int x1;
S1(){ x1 = 5;}
};
class S2 : public A {
public:
int x2;
S2(){ x2 = 6;}
};
class S12 : public S1, public S2 {
public:
int x12;
S12(){ x12 = 7;}
};
int main()
{
std::cout << "S1: " << sizeof(A) << std::endl;
std::cout << "S1: " << sizeof(S1) << std::endl;
std::cout << "S2: " << sizeof(S2) << std::endl;
std::cout << "S12: " << sizeof(S12) << std::endl;
}
在我的机器上,我得到以下输出:
S1:8
S1:12
S2:12
S12:28
我能理解为什么S1是8和S1,S2是12个字节,但我不明白为什么S12是28 - 我希望它是20,因为它必须有5个整数变量(每个4个字节)。登记/> 为什么S12为28个字节?
答案 0 :(得分:5)
您班级中有 7 个整数
S1::A::a
S1::A::b
S1::x1
S2::A::a
S2::A::b
S2::x2
x12
S12
包含两个 A
个对象。如果只需要一个A
对象,则需要从中继承:
#include <iostream>
struct A { int a = 1; int b = 2; };
struct S1 : virtual A { int x1 = 5; };
struct S2 : virtual A { int x2 = 6; };
struct S12 : S1, S2 { int x12 = 7; };
int main()
{
std::cout << "A: " << sizeof(A) << std::endl;
std::cout << "S1: " << sizeof(S1) << std::endl;
std::cout << "S2: " << sizeof(S2) << std::endl;
std::cout << "S12: " << sizeof(S12) << std::endl;
}
您获得的结果将比以前更依赖于实现 - 虚拟基类很棘手,不同的编译器倾向于使用不同的实现技术。我明白了:
A: 8
S1: 24
S2: 24
S12: 40