前面我们已经学习了指针的基本概念,接下来我们继续深入指针世界!
一、数组名的理解
上一次我们学习了指针访问数组,接下来我们看一段代码来具体理解。
#include <stdio.h>
int main()
{
int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
printf("&arr[0]=%p\n", &arr[0]);
printf("arr =%p\n", arr);
return 0;
}
我们发现数组名和数组首元素的地址打印出的结果一样,数组名就是数组首元素的地址,这个结论是对的,但是我们需要注意两个例外:
·sizeof(数组名),这里的数组名表示整个数组,计算的是整个数组的大小,单位是字节
·&数组名,这里的数组名表示整个数组,取出的是整个数组的地址
除此之外,任何地方的数组名都表示数组首元素的地址 。
我们再观察一段代码
int main()
{
int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
printf("&arr[0]=%p\n", &arr[0]);
printf("arr =%p\n", arr);
printf("&arr =%p\n", &arr);
return 0;
}
&arr[0],&arr,arr这三个地址