c - GCC 和 Visual Studio(32 位 Controller )中结构大小的差异

标签 c gcc struct

如下结构所示,var1后需填充1个字节自short以来结构体中使用,var3后面多补1个字节。这样,总数应该是 6。这就是我在 Visual Studio 中获得的值。维基百科上也提到了它 Data structure alignment .

typedef struct {char var1; short var2; char var3;} Bytes;

但在 GCC 中,它给出的大小为 8 字节。请让我了解该行为。

<小时/>

嗨, jack ,

我对以下结构进行了实验。

typedef struct
{
    char  charVar1;
    short shortVar2;
    char  charVar3;
}tsByte;

printf("\n Sizeo of Byte        : %d", sizeof(Byte));
printf("\n Sizeo of charVar1    : %d", sizeof(Byte.charVar1));
printf("\n Sizeo of shortVar2   : %d", sizeof(Byte.shortVar2));
printf("\n Sizeo of charVar3    : %d", sizeof(Byte.charVar3));
printf("\n Address of charVar1  : %x", &Byte.charVar1);
printf("\n Address of shortVar2 : %x", &Byte.shortVar2);
printf("\n Address of shortVar3 : %x", &Byte.charVar3);

结果如下。

Sizeo of Byte        : 8
Sizeo of charVar1    : 1
Sizeo of shortVar2   : 2
Sizeo of charVar3    : 1
Address of charVar1  : 4007e90
Address of shortVar2 : 4007e92
Address of shortVar3 : 4007e94

通常,当结构用作数组元素时,需要在结构末尾进行填充,以确保(其所有成员)正确对齐。但与最后一个元素的填充有点混淆。 “最后一个元素”的填充是基于 8/16/32 位 Controller 架构还是基于最大成员大小(此处简称)。

我觉得在 Visual Studio 中它是基于最大成员大小,因此您得到的大小为 6 个字节。而 gcc 编译器基于 Controller 架构,并且由于我使用 32 位 Controller ,它与 4 字节内存对齐。因此在 gcc 编译器中它是 8 个字节。如果我错了,请纠正我。

最佳答案

您将需要编写更多代码来研究编译器之间的差异。例如,尝试如下代码片段:

    // define a structure
    typedef struct {char var1; short var2; char var3;} Bytes;

    // allocate storage for the structure
    Bytes data;

    // tell me stuff about that structure
    printf("\nsizeof Bytes=%d, sizeof var1=%d, sizeof var2=%d, sizeof var3=%d",
         sizeof(data), sizeof(data.var1), sizeof(data.var2), sizeof(data.var3));

在 Eclipse/Microsoft C 编译器上,我得到:

    sizeof Bytes=6, sizeof var1=1, sizeof var2=2, sizeof var3=1

那么,为什么 Bytes=6 而 sizeof vars 的总和却是 4?对此的回答如下:

    printf("\naddrof var1=%08x", &data.var1);
    printf("\naddrof var2=%08x", &data.var2);
    printf("\naddrof var3=%08x", &data.var3);

产生:

    addrof data=0012ff40
    addrof var1=0012ff40
    addrof var2=0012ff42
    addrof var3=0012ff44

因此,即使 var1 是一个 char,它也使用两个字节,因此 Microsoft C 编译器实现了 K&R 记录的 ANSI C!!

您将需要使用 GCC 运行类似的代码来确定它如何格式化struct Bytes

关于c - GCC 和 Visual Studio(32 位 Controller )中结构大小的差异,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18021396/

相关文章:

c - 根据条件从字符串中提取子字符串

c - 为什么我们可以通过在 C 代码中重新分配变量来永久避免寄存器溢出?

c - 变量参数的指定初始值设定项

c - 成员(member)运营商 : How to use "my_var" actual value in "my_struct->my_var"?

c++ - GNU 链接器 : errors if pointer in header file is declared NULL and/or extern

在相同的结构类型中构建结构?

c - 小数据完美,大数据错误: A strange bubble sort question

c - 12 :4: error: variable-sized object may not be initialized

c# - 使用 CodeDom 以编程方式编译 C# Windows 窗体中的 C 代码?

c++ - 在 R 中编译 C++ 代码不再有效