指针偏移问题


(int)(p + 1)

这就是指针偏移问题了。把整数和指针相加,整数会自动乘以指针所指对象的大小。指针本身是指向一个地址的,再加上n个对象的大小,自然就指向了第n个对象的地址。所以(int)(p + 1)的结果是104(int类型占4字节)


&p[i]和(p+i)等价,是指针,指向第i个对象的地址

p[i]和*(p+i)等价,是第i个对象的值


//面试题

#include <stdio.h>

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

	printf("%d, %d /n", *(a + 1), *(p - 1));

 	return 0;
}
a与&a的值一样,但意义不一样, a+1的偏移量为一个int,相当于&a[1], &a+1的偏移量为整个数组。是数组类型的指针。


详细解释:

这个问题的关键是理解 &a 

a是一个数组名,也就是数组的首地址。
对a进行取地址运算符,得到的是一个指向数组的指针!!!!这句话尤为重要!
也就相当于
int (*p) [5] = &a;
p是一个指针,它指向的是一个包含5个int元素的数组!!

那么执行p+1后,p的偏移量相当于 p + sizeof(int) * 5 !!

而程序中强制将指针p转换成一个int* 那么 p -1 其实就是 p - sizeof(int)
所以,p -1 指向了数组中得最后一个元素,也就是 5