内存对齐问题

发布于 2022-09-05 01:52:47 字数 1512 浏览 21 评论 0

在看《征服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

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

梦幻的心爱 2022-09-12 01:52:47

不同平台不同编译器有不同的结果,在你的机器上以 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;
}
瑾兮 2022-09-12 01:52:47

楼上说的对

内存对齐的规则:
1、 对于结构的各个成员,第一个成员位于偏移为0的位置,以后每个数据成员的偏移量必须是min(#pragma pack()指定的数,这个数据成员的自身长度) 的倍数。
2、 在数据成员完成各自对齐之后,结构(或联合)本身也要进行对齐,对齐将按照#pragma pack指定的数值和结构(或联合)最大数据成员长度中,比较小的那个进行

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文