先看一段案例:
代码如下:
#include <stdio.h>
void printData(int array[3])
{
int i;
printf("printData:array的大小是:%d\n",sizeof(array));
for(i=0;i<3;i++){
printf("%d ",array[i]);
}
putchar('\n');
}
int main()
{
int array[3]={1,2,3};
printf("main:array的大小是:%d\n",sizeof(array));
printData(array); //数组名当成实际参数
return 0;
}
在编译后,编译结果如下:
将数组的元素改成10个元素,编译结果如下:
综合上述的案例,我们可以看出,形参中不存在数组的概念,即便中括号中约定了数组大小也无效。传递的只是一个地址而已,是数组的首地址(8个字节)。
而且在操作系统中,我们也是用8个字节来表示一个地址。
以上的代码可能会存在某些问题,但是我们为了验证某些东西,无伤大雅,在此,我们仍然可以看出sizeof的妙用(它是一个关键字)
#include <stdio.h>
void printData(int array[],int len)
{
int i;
printf("printData:array的大小是:%d\n",sizeof(array));
for(i=0;i<len;i++){
printf("%d ",array[i]);
}
putchar('\n');
}
int main()
{
int len;
int array[]={1,2,3,4,5,6};
len=sizeof(array)/sizeof(array[0]);
printf("main:array的大小是:%d\n",sizeof(array));
printData(array,len); //数组名当成实际参数
return 0;
}
前文提到
传递的只是一个地址而已,是数组的首地址。
既然它是传递一个地址,那么我们可以直接传递第一个元素的地址即可。
#include <stdio.h>
void printData(int array[],int len)
{
int i;
printf("printData:array的大小是:%d\n",sizeof(array));
for(i=0;i<len;i++){
printf("%d ",array[i]);
}
putchar('\n');
}
int main()
{
int len;
int array[]={1,2,3,4,5,6};
len=sizeof(array)/sizeof(array[0]);
printf("main:array的大小是:%d\n",sizeof(array));
printData(array[0],len); //数组名当成实际参数.数组名代表整个数组的首地址,同时,第一个元素的地址也是首地址。
return 0;
}
下面,再看看两段相似代码的编译结果对比:
第一段:
1、代码:
#include <stdio.h>
void changeData(int data)
{
data=data+100;
printf("data的数值为%d,地址为%p\n",data,&data);
}
int main()
{
int data=30;
changeData(data);
printf("data的数值为%d,地址为%p\n",data,&data);
return 0;
}
2、编译结果:
从编辑结果来看,两个data的地址不同。
第二段:
1、代码:
#include <stdio.h>
void changeData(int data[0])
{
data[0]=data[0]+100;
printf("data的数值为%d,地址为%p\n",data[0],&data[0]);
}
int main()
{
int data[2]={30,50};
changeData(data);
printf("data的数值为%d,地址为%p\n",data[0],&data[0]);
return 0;
}
2、编译结果:
从编译结果来看,两个data的地址相同。
总结: 对于普通的数值,传递的是数值,但操作的是不同的内存空间。 对于数组而言,数组名当作实参,传递的是地址,即相同的内存空间。