| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 531 人关注过本帖
标题:高手帮忙下,谢谢
只看楼主 加入收藏
starlyb
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2010-3-14
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:7 
高手帮忙下,谢谢
(1),struct{  int i;
        char c;
        double a;}a;
sizeof(a)为什么会等于11??这是选择题,答案是11.
(2),#include<stdio.h>
      {int x;struct *y;}*p;
       struct tt a[4]={20,a+1,15,a+2,30,a+3,17,a};
      main()
      {int i;
       p=a;
       for(i=1;i<=2;i++)  {printf("%d,",p->x);p=p->y;}
      }
为什么结果是20,15,请详细解说下,谢谢!   

[ 本帖最后由 starlyb 于 2010-3-21 16:42 编辑 ]
搜索更多相关主题的帖子: 选择题 
2010-03-21 08:55
C逍遥
Rank: 2
等 级:论坛游民
帖 子:18
专家分:12
注 册:2010-3-21
收藏
得分:0 
1  不同电脑或不同版本软件的话,对int char double 的规定是不同的,因此会出现11.
 
2010-03-21 10:13
ldg628
Rank: 12Rank: 12Rank: 12
等 级:火箭侠
威 望:3
帖 子:526
专家分:3036
注 册:2009-6-23
收藏
得分:8 
1. 对齐:按单个变量占字节数最大的数量为一个单位,各个变量排列时,若两个或多个没有占满一个单位时,可以在一个单位内排列,若超出了,则从超出的那个开 始,从下一个单位开始算,以此类推,最终按单位的倍数计总字节数,结果应该是16
(2). struct tt a[4]={20,a+1,15,a+2,30,17,a};赋值的结果是:
a[0].x = 20, a[0].y = &a[1];
a[1].x = 15, a[1].y = &a[2];
a[2].x = 30, a[2].y = 17;
a[3].x = &a[0], a[3].y = 0;//是不是你30与17之间漏了一个a+3啦,要不然可以组成一个循环链表
for(i=1;i<=2;i++) 循环的次数是2,p = a 可得p == &a[0];所以第一次循环时实际上是打印a[0].x所以为20,然后p = a[0].y == &a[1],在第二次打印的时候为a[1].x == 15
2010-03-21 10:21
hziee
Rank: 4
等 级:业余侠客
帖 子:64
专家分:257
注 册:2010-3-12
收藏
得分:0 
请把题目抄对了,再来问问题!
2010-03-21 10:34
csj_65
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:63
专家分:163
注 册:2010-3-12
收藏
得分:2 
楼主程序编的好看点行不?我编译的时候都没通过。。
程序代码:
struct
        {
        int i;
        char c;
        double a;
        }a;
        printf("%d",sizeof(a));
        return 0;

把sizef改为sizeof,stuct改为struct.
第一个编译结果是16.
2010-03-21 10:45
starlyb
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2010-3-14
收藏
得分:0 
xiexie

一切从爱好C开始
2010-03-21 16:53
starlyb
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2010-3-14
收藏
得分:0 
int两个,char一个,double八个,总就是十一个字节  

一切从爱好C开始
2010-03-21 17:08
用心对待生活
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2010-3-24
收藏
得分:0 
字节对齐问题
2010-04-01 13:49
快速回复:高手帮忙下,谢谢
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016015 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved