题记:
今天在网上看到一段c代码,比较有趣,是有关指针的。这种用法很有意思,而且一般人估计都会理解错。所以特此留下笔记。
先看一段代码:
int a[5]={1,2,3,4,5};
int *p=(int *)(&a+1); //数组指针 加一 进行正常的指针运算 走到数组尾
当我看到如上代码时,首先产生了如下疑问:
1、&a 应该是数组首地址变量的地址,那这个值是多少呢?
2、&a + 1 结果会是什么呢?
debug结论:
1、&a 的值还是数组首地址,只是 &a 对应的指针类型是 int[5] *
2、由于 &a 对应的指针类型是 int[5] * 的所以 +1 之后地址移动的字节数为 sizeof(int)*5 = 20。所以代码中 p 指针指向的是 数组最后一个元素的下一个地址即 a[6]的地址(当然这个a[6]是不存在的,这里只是为了描述更直接)。
最终分析:
1、变量名 a 从定义来看是一个size为5的数组。
2、&a 为数组变量a的地址,那么就是说它是类型为 int (*a)[5] 的指针。
3、&a + 1, 按指针的加法运算的规则 +1 是等价于地址移动类型size的地址,也就是&a+1 移动的地址为 sizeof(int)*5
4、所以最终 p 指向的是 数组元素 a[6] (这个元素不存在,这里只是为了更加形象的描述)。