一道微软亚洲工程院C语言笔试题的解答

题目:
struct S
{
  int i;
  int * p;
};

void main()
{
  struct S s;
  int * p = &s.i;
 
  p[0] = 4;
  p[1] = 3;
 
  s.p = p;
 
  s.p[1] = 1;
  s.p[0] = 2;
}


问程序会在哪一行死掉。

分析:这道题有点难度。如果你对指针掌握的不错的话,仔细分析,相信最终还是可以迎刃而解的。下面就来逐条分析

  struct S s;
  int * p = &s.i;/*取成员s.i的地址*/

  p[0] = 4;;/*设置成员s.i为4。因为指针p指向i地址,p[0]指向i*/
  p[1] = 3;/*设置成员s.p为3。因为p[0]指向s.i,p[1]指向指针s.p*/
  
  s.p = p;/*重新设置指针s.p为s.i的地址*/
  
  s.p[1] = 1;/*置s.p指针为1。因前面s.p指向s.i的地址,固s.p[1]指向s.p*/
  s.p[0] = 2;/*因为s.p指针已经通过前面被设置为1,即非法地址,所以s.p[0]想通        过s.p去访问s.i显然是非法的。*/

  在内存中的对应关系:
 | s.i    | s.   |
  | p[0]   | p[1]   |
  | s.p[0] | s.p[1] |
 
后话:这里出题者故意将s.p[0]和s.p[1]的访问次序对调,就是想通过设置s.p[1]搞死s.p[0]的相关操作。如果先执行s.p[0] = 2,然后执行s.p[1] = 1,那么所有代码都正常通过。
 
答案:程序执行最后一句s.p[0] = 2死掉。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值