首先,看一段代码:
#include <stdio.h>
int main(void)
{
int a[5] = {0,1,2,3,4};
printf("a = %d , &a = %d \n", a, &a);
return 0;
}
该代码运行结果为:
可见,对于一个数组:
int a[5] = {0,1,2,3,4};
a与&a的值是相同的。为什么呢?
a是数组名,是一个数据区的常量,对其取地址(&a)就可以得到数组存储区域的地址,同样,a本身也代表了数组存储区的首地址。所以,a与&a的值是一样的。但是,虽然a与&a指向同一个地址,但是他们的含义是不同的。下面我们修改一下上面的代码看看”a+1”与”&a+1”是否还相等?修改后的代码运行结果为:
可见,a+1的值比a的值大4,即sizeof(a[0]);&a+1比&a的值大20,即sizeof(a)。由此,可得出结论:a+1指向的地址相对与a指向的地址向后偏移了sizeof(a[0])个字节,&a+1指向的地址相对与&a指向的地址向后偏移了sizeof(a)个字节,其描述图如下:
下面分析一段代码:
#include <stdio.h>
int main(void)
{
int a[5] = {0,1,2,3,4};
int *ptr = (int*)(&a+1);
printf("*(a+1) = %d, *(ptr-1) = %d\n",*(a+1), *(ptr-1));
return 0;
}
运行结果为:
*(a+1) = 1, *(ptr-1) = 4
*(a+1) = 1
,是因为a+1
代表数组第二个元素的地址,即&a[1]
,*(a+1)
为取该地址上的值,即为1;*(ptr-1)=4
,是因为ptr指向的是整个数组内存区域之后的内存,即数组最后一个元素之后的地址,ptr-1
就是指向数组的最后一个元素,*(ptr-1)
为取该地址上的值,即为4。
以上就是今天分享的关于数组的一个小知识点,欢迎转发!