| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 538 人关注过本帖
标题:指向结构体数组指针,第一次看见这样的题,该如何读?
只看楼主 加入收藏
菜鸟向前冲
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2009-11-6
结帖率:0
收藏
 问题点数:0 回复次数:3 
指向结构体数组指针,第一次看见这样的题,该如何读?
#include <stdio.h>
                 struct s1{
                       char *s;
                       struct s1 *ptr;
             };
            struct s1 a[]={
                       {"efgh",a+1},
                       {"ijkl",a+2},
                       {"mnop",a}};
                 struct s1 *p=a;
                 void main( ) {
                       int i;
                       for(i=0;i<3;i++ )
                    printf({"%s %s %c %s\n",a.s,a.ptr->s,a.s++,
                           ++p++->ptr->s+1);
答案是fgh jkl e kl
      jkl nop k op
      nop fgh p gh
怎么会出现这样结果?
搜索更多相关主题的帖子: 指针 结构体 
2009-11-16 00:17
UserYuH
Rank: 12Rank: 12Rank: 12
来 自:毅华
等 级:火箭侠
威 望:8
帖 子:720
专家分:3300
注 册:2009-8-10
收藏
得分:0 
应该是这样:
for(i=0;i<3;i++ )
   printf("%s %s %c %s\n",a[i].s,a[i].ptr->s,*a[i].s++,++p++->ptr->s+1);
结果:
     fgh jkl e kl
     kl nop j op
     op gh n h
·
第一次循环:
i=0
有递增递减符号就要注意了,printf函数从右算起,再从左开始输出。
第一个%s:
先算++p++->ptr->s+1(这个一会再讲),再算*a[0].s++,a[0].s地址增1 ,第一个%s输出:fgh
第二个%s:
前面先算了++p++->ptr->s+1 可这样看:++(p->ptr->s)+1 和 p++ ,这是先把p->ptr->s地址增1,再把p地址增1,第二个%s输出时,由于p->ptr->s等于a[0].ptr->s,a[0].ptr->s地址已经移了一位,所以输出:jkl
第三个%c:
*a[0].s++ 先取*a[0].s,再把a[0].s地址增1,输出:e
第四个%s:
++p++->ptr->s+1    看成++(p->ptr->s)+1 ,p->ptr->s地址增1加1,移动2,输出:kl  ,最后p地址再增1
·

·
同一个变量有自增自减出现在一个表达式里有争议,这样用法以后要避免。楼主要熟悉结构体指针这个列不合适。

努力—前进—变老—退休—入土
2009-11-16 02:54
菜鸟向前冲
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2009-11-6
收藏
得分:0 
这是最近在做的一个题 谢楼上详细解答 可第二行输出kl nop  j op看不懂 按你所说 i=1 先算*a[1].s++ 先取a[1] 然后将a[1].s地址增1 第一个%s应该输出jkl啊
2009-11-16 09:55
UserYuH
Rank: 12Rank: 12Rank: 12
来 自:毅华
等 级:火箭侠
威 望:8
帖 子:720
专家分:3300
注 册:2009-8-10
收藏
得分:0 
第一次循环++p->ptr->s地址已经移动1,到第二循环又移动1,a[1].s移动两次所以输出:kl   .后面输出一样,注意之前的地址变动。

努力—前进—变老—退休—入土
2009-11-16 10:21
快速回复:指向结构体数组指针,第一次看见这样的题,该如何读?
数据加载中...
 
   



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

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