地址与常数的加减不是简单的加减,“地址+常数”的结果=地址值+常数*该指针类型所占的字节数。
例子如下:
int a[5]={1,2,3,4,5};
int *ptr=(int *)(&a+1);
printf("%d",*(ptr-1));
输出结果为5。为什么呢?
首先&a表示数组a[5]的首地址,有的可能会说a不是数组首地址吗?a是数组首元素的地址,所以a和&a是相等的。
&a+1表示&a+1*sizeof(int[5])=数组a[5]的地址+5。
那么&a+5就指向了a[5]的后面,ptr的指向就超出了数组的范围,那么ptr-1就向前挪一个指针,就指向了a[5]即5。
可能还有的人会有疑问:&a+1=&a+1*sizeof(int[5]),那么ptr-1应该等于ptr-1*sizeof(int[5]),那么不就又指向a[0]了吗?
这里需要注意:ptr与&a的类型是不一样的,ptr是(int *)类型,&a是(int[5] *),所以&a+1=&a+1*sizeof(int[5]),&a加上5个int,
而ptr-1=ptr-a*sizeof(int),ptr减去一个int。
PS:希望我说明白了。