有任何不懂的问题可以评论区留言,能力范围内都会一一回答
首先我们要明确一点,数组名就是数组名是首元素的地址,这个在一维数组中是没有歧义的
我们直接上代码验证
由上面的代码可知,在一维数组中arr和arr[0]是等价的,无论是从值的本身还是参与运算,(二维数组中会有差异详见数组与指针思考(1)-CSDN博客)
但是在两种情况下是例
其实数组名是数组首元素的地址~
但是有2个例外:
1. sizeof(数组名)
这里的数组名表示整个数组,计算的是整个的大小,单位是字节
2.&数组名
这里的数组名也表示整个数组,取出的是整个数组的地址
除此之外,所有的数组名都是数组首元素的地址
那我们思考一下上面这个图片
为啥同样都是sizeof(arr) / sizeof(arr[0]);
一个结果是6,一个结果是2,到底哪里出错了
首先我们来看s1,sizeof(arr)是数组的大小及6个元素大小之和,sizeof(arr[0])是一个数组大小,一除当然是6了
但是s2为什么是2呢?
我们通过函数到底把什么传过去了?
很显然这个地方我们传的不是数组啊!这个地方我们传参本质并没有传整个数组,而是将数组首元素的地址传进去了,但是因为本次编译用的是x64的环境所以地址的大小是8个字节,而int类型的元素大小是四个字节,因此sz2=sizeof(arr) / sizeof(arr[0])=2
arr 是数组名,数组名表示数组首元素的地址
数组传参的本质,传递的是数组首元素的地址
所以形参即使写成数组的形式,本质上也是一个指针变量
所以这个地方我们把void exam(int arr[6])
替换成一下两句都是一致的
void exam(int arr[])
void exam(int*arr)
顺带一嘴,其实二维数组可以这样写arr[][2],而第一个[]代表指针。
因此我们如果需要通过sz=sizeof(arr) / sizeof(arr[0]);得到数组元素个数
那就不要放到函数中去求,可以直接在函数外求,并把sz传给函数即可,就像下图这样
#define _CRT_SECURE_NO_WARNING
#include <stdio.h>
void exam(int arr[6],int sz2) {
printf("sz2=%d\n", sz2);
}
int main(void) {
int arr[6] = {1,2,3,4,5,6};
int sz = sizeof(arr) / sizeof(arr[0]);
exam(arr,sz);
return 0;
}
下一章我们讲多维数组的传参本质多维数组传参本质-CSDN博客