目录
1.数组名的理解
int arr[10] = { 1,2,3,4,5,6,7,89,10 };
int* p = &arr[0];
上面的代码展示:我们使用 &arr[0] 的方式拿到了数组第⼀个元素的地址,但是其实数组名本来就是地址,而且是数组首元素的地址,下面通过代码展示;
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
int arr[10] = { 1,2,3,4,5,6,7,89,10 };
printf("arr[0]=%d\n", &arr[0]);
printf("arr=%d\n", arr);
return 0;
}
通过左边代码运行展示可以看到,数组名和数组首元素地址是一样的,数组名就是数组首元素(第一个元素)的地址
但是还是有两个例外的,下面看代码:
1.sizeof(数组名),sizeof 中单独放数组名,这里的数组名表示整个数组,计算的是整个数组的大小, 单位是字节;
#include<stdio.h>
int main()
{
int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
printf("%d\n", sizeof(arr));
return 0;
}
运行结果是计算了整个数组的大小,一个整型变量的大小是4个字节,10个就是40个字节,所以通过运行,我们可以知道sizeof计算的是整个数组的大小
2. & 数组名,这里的数组名表示整个数组,取出的是整个数组的地址(整个数组的地址和数组首元素的地址是有区别的)
#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);
printf("&arr=%p\n", &arr);
printf("&arr=%p\n", &arr+1);
return 0;
}
通过左边图片运行上面的代码可以知道 &arr 和 &arr+1 之间相差 40 个字节
下面通过代码的形式,全部结合起来,看起来更直观:
通过上面的总结:我们发现 &arr[0] 和 &arr[0]+1 相差4个字节, arr 和 arr+1 相差4个字节,是因为 &arr[0] 和 arr 都是首元素的地址,+1 就是跳过⼀个元素。 但是 &arr 和 &arr+1 相差40个字节,这就是因为 &arr 是数组的地址,+1 操作是跳过整个数组的。 到这里大家应该搞清楚数组名的的区别了吧
2.使用指针访问数组
- 因为数组在内存中是连续存放的
- 数组名就是首元素的地址