Chinaunix首页 | 论坛 | 博客
  • 博客访问: 33738
  • 博文数量: 9
  • 博客积分: 172
  • 博客等级: 入伍新兵
  • 技术积分: 105
  • 用 户 组: 普通用户
  • 注册时间: 2012-09-08 21:15
文章分类

全部博文(9)

文章存档

2012年(9)

最近访客

分类: C/C++

2012-10-09 20:41:56

作者:   电子科技大学   小武
来源:   http://blog.chinaunix.net/space.php?uid=27778449



我说的很直白,简单易懂,给在迷茫的孩子和自己总结与复习。
这是我在华清培训的时候老师讲的一道题,老师讲的我想哭,后来自己想了想


下面这个是一个比较经典的例子

main()
{
  int a[5]={1,2,3,4,5};

   int *ptr=(int *)(&a+1);

   printf("%d,%d",*(a+1),*(ptr-1));
}


输出:2,5
*(a+1)就是a[1],*(ptr-1)就是a[4],执行结果是2,5

                                                     重要的来了哈


&a+1不是首地址+1,系统会认为加一个a数组的偏移,是偏移了一个数组的大小
int *ptr=(int *)(&a+1);
则ptr实际是&(a[5]),也就是a+5


                                                         原因如下:
&a是数组指针,其类型为 int (*)[5];
而指针加1要根据指针类型加上一定的值,
不同类型的指针+1之后增加的大小不同
a是长度为5的int数组指针,所以要加 5*sizeof(int)
所以ptr实际是a[5]
但是prt与(&a+1)类型是不一样的(这点很重要)
所以prt-1只会减去sizeof(int*)
a,&a的地址是一样的,但意思不一样,a是数组首地址,也就是a[0]的地址,&a是对象(数组)首地址,a+1是数组下一元素的地址,即a[1],&a+1是下一个对象的地址,即a[5].

 


阅读(1576) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~