内存对齐问题

在看《征服C指针》这本书,看到内存对齐这块时却产生了如下疑问.我看到书中这段的时候分析结构体sizeof(Hoge)=32(前提sizeof(int)为4,sizeof(double)为8,sizeof(char)为1.)可书上却说是24,我再电脑上运行的话也是32.网络上找勘误表也没找到。
我的分析如下,请各位指正,如有错误环境指出:
sizeof(double)为8,所以,结构体第一个成员int + 4个填充 char +7个填充对齐,加上两个double占用16,故sizeof(Hoge)为32,不知道这么理解是不是正确?

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
阅读 2.7k
2 个回答

不同平台不同编译器有不同的结果,在你的机器上以 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;

int main () {
    printf("%ld", sizeof(Hoge)); // 24
    return 0;
}
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进