分享

数组问题:a与&a有什么不同?

 嵌入式大杂烩 2021-08-20

#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)个字节,其描述图如下:

看了这张图,想必大家已经对a与&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。

以上就是今天分享的关于数组的一个小知识点,希望对您有帮助。感谢您的阅读,欢迎持续关注!

每日一句

为了未来美一点,现在必须苦一点。低头不算认输,放弃才是懦夫。

    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多