明确:
数组作为函数参数和普通的参数是有区别的;
函数中普通的参数
如同void insert(int a,int b)之类的传递分为3种方式传递
- 值传递
- 指针传递,指针值的传递,
- 引用传递,它们的参数的传递是将实参的值赋给形参。
而数组作为函数参数传递:
而数组作为函数参数传递,值传递就是指针地址的传递,而这就与普通参数不一样了;因为数组的数据太多了,将其一一赋值既麻烦又浪费空间,所以数组作为参数传递给函数的只是数组首元素的地址,函数在需要用到后面元素时再按照这个地址和数组下标去查找。所以,函数调用的数组会对本身的数组造成影响,这点和普通参数的值传递是不同的。
同时,**作为函数形参的数组和指针可以互换,这种转换仅限于函数形参的声明。**这是一种便利,传递时数组会蜕变为指针,事实上数组从来没有传入过函数。
eg:以下2个声明是等价的
void insert(int * arr);
void insert(int arr[]);
调用:
insert(arr);
注意:因为传入数组名时,数组名代表的就是数组的首地址,所以数组名是不可以用“&”符来取别名的,即当数组作为函数参数进行传递时,不可以使用引用类型进行传递;

且数组长度不是参数类型的一部分。函数和编译器都不知道传统给它的数组的长度的大小。——所以我们将数组作为函数参数进行传递时会另外再传入一个数组长度;
编程时的一些代码示例:
//排序函数1————数组值传递
void sortHero(Hero heroArr[],int len) {
for (int i = 0; i < len-1; i++) {
for (int j = 0; j < len - 1 - i; j++) {
if (heroArr[j].age > heroArr[j + 1].age) {
Hero temp = heroArr[j];
heroArr[j] = heroArr[j + 1];
heroArr[j + 1] = temp;
}
}
}
}
//排序函数2————数组地址传递
void sortHero(Hero * heroArr, int len) {
for (int i = 0; i < len - 1; i++) {
for (int j = 0; j < len - 1 - i; j++) {
if (heroArr[j].age > heroArr[j + 1].age) {
Hero temp = heroArr[j];
heroArr[j] = heroArr[j + 1];
heroArr[j + 1] = temp;
}
}
}
}
//调用:
int len = sizeof(heroArr) / sizeof(heroArr[0]);
sortHero(heroArr, len);
因为数组长度不是参数类型的一部分。函数和编译器都不知道传统给它的数组的长度的大小。==——所以我们将数组作为函数参数进行传递时会另外再传入一个数组长度len;
本文详细介绍了数组作为函数参数时的传递机制,指出其不同于普通参数的值传递,实际上是传递数组首元素的地址。由于数组长度信息不在参数类型中,因此需要额外传递数组长度。同时,数组与指针在函数声明中可以互换,并通过示例展示了两种排序函数的实现。强调数组名作为地址不能与引用结合,并提醒在实际编程中注意数组长度的传递。

450

被折叠的 条评论
为什么被折叠?



