数组做输入,退化为指针
以一个简单的程序为例,如给数组排序
void print_array(int *arr, int len);
void sort_array(int *a, int n);
int main(void)
{
//建立一个无序的数组
int a[] = { 10,11,2,3,5,88,4,6,4,32,12 };
//获取元素个数
int n = sizeof(a) / sizeof(a[0]);
printf("排序前\n");
//首先进行一次输出,数组、长度作为输入参数
print_array(a, n);
//给数组排序
sort_array(a, n);
printf("排序后\n");
//再次输出数组的元素
print_array(a, n);
printf("\n");
system("pause");
return 0;
}
void print_array(int *arr, int len)
{
int n = sizeof(arr) / sizeof(arr[0]);//元素个数
printf("指针型数组长度%d\n",n);
int i = 0;
for ( i = 0; i < len; i++)
{
printf("%d ",arr[i]);
}
printf("\n");
}
void sort_array(int *a, int n)
{
int i, j;
int temp;
//选择法排序
for (i = 0; i < n - 1; i++)
{
for (j = i + 1; j < n; j++)
{
if (a[i] > a[j])
{
temp = a[i];
a[i] = a[j];
a[j] = temp;
}
}
}
}
执行结果如下
在上面的程序中,数组a作为一个参数被传入函数sort_array()和print_array(),跟它同时被传入的还有数组长度n,为什么需要这两个参数?
以函数print_array()为例
void print_array(int *arr, int len)
{ //int型有32位,4个字节,arr[x]也是32位,4个字节
int n = sizeof(arr) / sizeof(arr[0]);//元素个数
printf("指针型数组长度%d\n",n);
int i = 0;
for ( i = 0; i < len; i++)
{
printf("%d ",arr[i]);
}
printf("\n");
}
可以看到,数组 a 被交给了形参 int *arr 这就是一个标准的指针,而对于函数print_array()来说,不论 a 是个指针、地址、数组名甚至是一个NULL,它都会被当做一个指针使用,C语言就是这么单纯不做作。
不过这也带来了一个问题,它把 a 当成指针了,那数组的长度怎么获得呢?只通过 a 本身是怎么也不可能知道的。就像是print_array()的第3、4行
int n = sizeof(arr) / sizeof(arr[0]);//元素个数
printf("指针型数组长度%d\n",n);
这句话使用了算数组arr中的元素个数的,很常见,它的输出结果在上面就出现过了,n = 1,也就是说在arr中数组长度这个信息是不存在的,这就是为什么
void print_array(int *arr, int len)会用到第二个参数int len,它的作用就是告诉print_array()我给你传进去的数组它有多长。
总的来说,这篇博客想表达的只有一句话:
如果数组作为函数参数,数组形参退化为指针
————————————————
版权声明:本文为CSDN博主「三日凌空」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_42182035/article/details/98853900