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 数组的偏移,是偏移了一个数组的大小(本例是
5 个int)
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].
偏移了一个数组的大小
最新推荐文章于 2023-07-10 20:20:14 发布