传入函数后的数组成了什么?
对于一个普通变量传入的是值,对于一个指针传入的也是值,只不过这个值是一个地址。
先看一下下面的代码
#include<stdio.h>
void minmax(int a[],int len,int *max,int *min);
int main(void)
{
int a[]={1,2,3,4,5,6,7,8,9,12,13,14,16,17,21,23,55};
int min, max;
printf("main sizeof(a)=%lu\n",sizeof(a));
printf("main a=%p\n",a);
minmax(a,sizeof(a)/sizeof(a[0]),&min,&max);
printf("a[0]=%d",a[0])
printf("min=%d,max=%d\n",min,max);
return 0;
}
void minmax(int a[],int len,int *max,int *min){
int i;
printf("minmax sizeof(a)=%lu\n",sizeof(a));
printf("minmax a=%p\n",a);
a[0]=1000;
*min=*max=a[0];
for(i=1;i<len;i++){
if(a[i]<*min){
*min=a[i];
}
if(a[i>*max]){
*max=a[i];
}
}
}
为什么参数列表里数组a后面必须是空的[],为什么方括号里写了数字也没有用,原因就在于它其实是一个指针。
void minmax(int a[],int len,int *max,int *min);
把a[]改成*a,会发现编译通过了,连warning都没有了。
其他的地方我们都在当作数组用它,函数里面的a[0],a[i],这是可以的。数组和指针好像存在某种联系。
函数参数列表中的数组实际上是指针
sizeof(a)实际上就是sizeof(int *)
但是可以用数组的运算符[]运算
因此下面四种运算是等价的
int sum(int *ar,int n);
int sum(int *,int n);
int sum(int ar[],int n);
int sum(int [],int n);
数组变量本身就是特殊的指针
数组变量本身表达地址,因此
int a[10];
int *p=a;//取地址无需用&
但是数组的单元表达的是变量,需要用&取地址。
a==&a[0]
[]运算符可以对数组做,也可以对指针做。
p[0]<==>a[0];
*运算符不仅可以对指针做,还可以对数组做。
数组变量是常量指针,所以数组变量不能被赋值。
int a[]<=>int *const a