忙里偷闲在看《征服C指针》这本书,虽然这本书写的比较基础可以是还是从中发现了一些有意思的地方,不过当看到内存对齐这块时却产生了如下疑问.

typedef struct
{
    int int1;
    double double1;
    char char1;
    double double2;
}Hoge;

那么问题来了,sizeof(Hoge)为多少?

作者交代了,在其环境中sizeof(int)为4,sizeof(double)为8,sizeof(char)为1.

作者给出的答案让我震惊:24!

/*
    Name: 内存对齐
    Copyright: 52coder.net
    Author: 52coder
    Date: 03/06/17 17:24
    Description: pointer
 */
#include <stdio.h>
#include <stdlib.h>

typedef struct
{
    int int1;
    double double1;
    char char1;
    double double2;
}Hoge;

int main()
{
    Hoge hoge;
    printf("hoge size....%zu\n",sizeof(Hoge));
    printf("hoge ……%p\n",&hoge);
    printf("int1……%p\n",&hoge.int1);
    printf("double1……%p\n",&hoge.double1);
    printf("char1……%p\n",&hoge.char1);
    printf("double2……%p\n",&hoge.double2);
    
    printf("sizeof(int) %zu\n",sizeof(int));
    printf("sizeof(int) %zu\n",sizeof(char));
    printf("sizeof(int) %zu\n",sizeof(double));
    
    
    return 0;
}
hoge size....32
hoge ……0x7fff5fbff798
int1……0x7fff5fbff798
double1……0x7fff5fbff7a0
char1……0x7fff5fbff7a8
double2……0x7fff5fbff7b0
sizeof(int) 4
sizeof(int) 1
sizeof(int) 8
Program ended with exit code: 0

原因是什么呢?是作者搞错了吗?
真正的原因是:
不同平台不同编译器有不同的结果,在你的机器上以 8 为单位,在作者的机器上以 4 为单位
事实上你可以使用 #pragma pack(n) 指定对齐的单位:

#include <stdio.h>
#include <stdlib.h>

#pragma pack(4)
typedef struct {
    int int1;
    double double1;
    char char1;
    double double2;
} Hoge;
#pragma pack()

int main ()
{
    printf("%ld", sizeof(Hoge)); // 24
    return 0;
}