为方便在程序中对数组操作,经常会定义一些操作数组的功能函数,这些函数往往会将数组作为函数参数使用。
一、要求:
1.保证形参与实参的数组是相同的数据类型
2.有明确的数组说明:数组维数、长度
c
void func1(int arr[5]);
void func2(int arr[],int n); # n表示数组长度
# 调用函数,直接传入对应的数组作为实参
func1(arr[5]);
func2(arr[],5);
注意:在形参中改变数组中的元素,实参中的数组元素也会改变
在多维数组作为函数参数时,可以指定多维数组中每一维的长度,也可以省去多维数组中第一维的长度。示例:
c
void func1(int arr[3][4]);
void func2(int arr[][4],int n)
# 调用函数
func1(arr[3][4]);
func2(arr,3);
二、 数组作为函数参数的 3 种等价写法
C 语言允许多种写法声明数组参数,但底层逻辑完全一致(都等价于指针),新手可以优先用最直观的写法:
c
#include <stdio.h>
// 写法1:最直观(推荐新手),用数组形式声明
void func1(int arr[], int len) {
arr[0] = 99; // 修改原数组第一个元素
}
// 写法2:指定数组长度(仅作提示,编译器会忽略这个长度)
void func2(int arr[10], int len) {
arr[1] = 88; // 修改原数组第二个元素
}
// 写法3:显式指针形式(底层等价写法,进阶常用)
void func3(int *arr, int len) {
arr[2] = 77; // 修改原数组第三个元素
}
int main() {
int nums[] = {1,2,3,4,5};
int len = sizeof(nums)/sizeof(nums[0]); // 仅在原数组定义处能正确计算长度
func1(nums, len);
func2(nums, len);
func3(nums, len);
// 输出:99 88 77 4 5(原数组被修改)
for(int i=0; i<len; i++) {
printf("%d ", nums[i]);
}
return 0;
}
关键解释:
- 写法 2 中的
int arr[10]里的10没有实际意义,哪怕你传的数组长度是 5,编译器也不会报错; - 三种写法的汇编代码完全一致,本质都是接收
int*类型的指针。