免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 13519 | 回复: 54
打印 上一主题 下一主题

struct 对齐 [复制链接]

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-11-21 12:02 |只看该作者 |倒序浏览
struct A
{
    char a;
    char b;
    int c[0];
};

sizeof(A) = 4;

为什么呢?

注意:

struct A
{
    char a;
    char b;
    int c;
};

sizeof(A) = 8;

论坛徽章:
0
2 [报告]
发表于 2011-11-21 12:11 |只看该作者
int c[0];

不会分配空间的吧?

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
3 [报告]
发表于 2011-11-21 12:14 |只看该作者
本帖最后由 zylthinking 于 2011-11-21 12:16 编辑

因为里面有个 int, 所以 struct A本身以最大的对齐, 因此为4,  占用内存长度自然是 sizeof(char) * 2 + padding.  至于为什么存在 int c[0] 也要考虑它, 我只能说我觉得肯定考虑了; 至于为什么一定存在padding, 我自己找的理由如下: struct A如果按照 4 字节对齐, 自身长度又是 2, 那么 struct A a[2] 占多少字节? a[0], a[1] 肯定都在 4字节边界上, 但两者之间的空洞能说不是 a[0]的吗? 如果要那么说, 那么数组是连续存储的又怎么保证? 所以让他后面带 padding 是最自然的方案。

至于后面那个, int 也是 4 字节对齐,  struct A也是 4 字节对齐, char a, b 后面填2个padding 就是了, 加起来  8

论坛徽章:
0
4 [报告]
发表于 2011-11-21 12:26 |只看该作者
因为里面有个 int, 所以 struct A本身以最大的对齐, 因此为4,  占用内存长度自然是 sizeof(char) * 2 + pa ...
zylthinking 发表于 2011-11-21 12:14



    32位的机器下,即使 STRUCT A中没有int,比如:
            struct A
                  {
                      char a;
                      char b;

                     /* int    c;*/
                  }

       sizeof(A)应该也是4的吧。还有也好像并不是“因为里面有个 int, 所以 struct A本身以最大的对齐, 因此为4”
如果      
              struct A
                    {
                            char     a;
                            char     b;
                            double c;
                    }
那么sizeof (A)应该也是1+1+2(补充位)+8=12的,而不是按最大的对齐8+8=16。

论坛徽章:
0
5 [报告]
发表于 2011-11-21 12:28 |只看该作者
不知道我有没有理解对三楼的意思~~如果误解了抱歉哈!~

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
6 [报告]
发表于 2011-11-21 12:30 |只看该作者
回复 4# windy2335
这个还真是不知道, 我是瞎猜的; 你的结论应该更靠普。
double 的对齐原则之前有个帖子提到了, 默认是 4, 但可以通过编译选项调整为8, 所以你说的那个是 12 还是 16 都有道理的。

论坛徽章:
0
7 [报告]
发表于 2011-11-21 12:32 |只看该作者
通常是按字对齐的,32位的话,也就是一个sizeof(int)的大小。

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
8 [报告]
发表于 2011-11-21 12:37 |只看该作者
回复 4# windy2335

咦, 不对, 我做了个实验,

  2 #include <stdio.h>
  3 #include <unistd.h>
  4
  5 struct A{
  6     char a;
  7 };
  8
  9 int main(int n, char** v){
10     struct A b[5];
11     printf("wake up: %d, %d, %d\n", sizeof(struct A),  ( (int )(&b[0]) % 4), ((int) (&b[3]) % 4));
12     return 0;
13
14 }


输出为 1, 0, 3, 那说明结构体最小对齐还真不是 4

论坛徽章:
17
水瓶座
日期:2013-08-29 12:09:27白羊座
日期:2014-08-07 12:36:42丑牛
日期:2014-07-24 12:44:41寅虎
日期:2014-04-16 16:15:33寅虎
日期:2014-03-12 09:28:43摩羯座
日期:2014-03-06 13:22:04技术图书徽章
日期:2014-03-06 11:34:50天蝎座
日期:2014-01-09 11:31:44寅虎
日期:2013-12-27 17:01:44双子座
日期:2013-12-27 12:32:29双子座
日期:2013-12-25 09:03:33丑牛
日期:2013-12-24 16:18:44
9 [报告]
发表于 2011-11-21 12:43 |只看该作者
我测试了下,估计原因因该是zylthinking说的。。。

struct A
{
        char a;
        char b;
        char c[0];
}
这个是2

struct A
{
        char a;
        char b;
        short c[0];
}
这个还是是2

struct A
{
        char a;
        char b;
        int c[0];
}
这个是4

论坛徽章:
0
10 [报告]
发表于 2011-11-21 12:52 |只看该作者
哈哈

我现在用的电脑没编译器.....

不过可能我的理解可能有点问题,回头查查...
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP