C语言:用数组名作函数参数,c 函数调用数组时为什么形参数组名可以被赋值?

C语言数组名作函数参数_百度文库
赠送免券下载特权
10W篇文档免费专享
部分付费文档8折起
每天抽奖多种福利
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
C语言数组名作函数参数
阅读已结束,下载本文需要
想免费下载更多文档?
定制HR最喜欢的简历
下载文档到电脑,同时保存到云知识,更方便管理
加入VIP
还剩4页未读,
定制HR最喜欢的简历
你可能喜欢数组名作函数的实参,数组做函数的形参问题
[问题点数:20分]
数组名作函数的实参,数组做函数的形参问题
[问题点数:20分]
只显示楼主
取消只显示楼主
匿名用户不能发表回复!|没有更多推荐了,
加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!在C语言中,数组作为参数,是怎样在函数之间传递的啊??_百度知道
在C语言中,数组作为参数,是怎样在函数之间传递的啊??
哪位大神能够解释得详细点吗??越详细越还好........
额,这个我们还没学到指针的,能讲得通俗易懂点吗??
我有更好的答案
很简单的,数组作为函数参数传递的时候只要是数组名就可以了,因为数组名本身就是数组的首地址 .给个程序看看#include&stdio.h& #define N 3 int array[N][N]; void main() { //在主函数内声明被调函数 void convert(int array[][3]); int i,j; printf(&输入数组:\n&); for(j=0;j&N;j++) for(i=0;i&N;i++) scanf(&%d&,&array[i][j]); printf(&\n&); for(j=0;j&N;j++) { for(i=0;i&N;i++) printf(&%d\t&,array[i][j]); printf(&\n&); } //调用矩阵转置函数 convert(array); printf(&\n&); for(i=0;i&N;i++) { for(j=0;j&N;j++) printf(&%d\t&,array[i][j]); printf(&\n&); } } void convert(int array[][3]) { int i,j,t; for(i=0;i&N;i++) for(j=0;j&N;j++)//设置数组中转置矩阵元素交换 { t=array[i][j]; array[i][j]=array[j][i]; array[j][i]=t; } }
采纳率:26%
数组作为参数是按地址传递的数组名就是数组的首地址。因此在数组名作函数参数时所进行的传送只是地址的传送, 也就是说把实参数组的首地址赋予形参数组名。形参数组名取得该首地址之后,也就等于有了实在的数组。实际上是形参数组和实参数组为同一数组,共同拥有一段内存空间。
本回答被提问者采纳
函数里写明数组类型,数组名再加中括号就行了,但同时最好写上数组里的元素个数;要么直接用指针(你没学就不说了)!如 int fun(int a[],int n);
//声明一个函数,传入一个a数组,n代表行标调用 fun(a,n)就行了;怎样??懂了吧!!
本回答被网友采纳
在调用函数时,给一个数组类型的参数,通过下标传递。
和指针一样,数组名就是首地址,直接传递数组名,
取数组首地址做地址传递,如要传送int a[10],可以在函数中写,fun(int *a)
其他3条回答
为您推荐:
其他类似问题
您可能关注的内容
c语言的相关知识
换一换
回答问题,赢新手礼包
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。C语言中数组名作为参数实现函数传递
作者:用户
本文讲的是C语言中数组名作为参数实现函数传递,
用数组名作函数参数与用数组元素作实参有几点不同。
1) 用数组元素作实参时,只要数组类型和函数的形参变量的类型一致,那么作为下标变量的数组元素的类型也和函数形参变量的类型是一致的。因此,并不要求函数的形参也是下标变量。换句话说,对
用数组名作函数参数与用数组元素作实参有几点不同。
1) 用数组元素作实参时,只要数组类型和函数的形参变量的类型一致,那么作为下标变量的数组元素的类型也和函数形参变量的类型是一致的。因此,并不要求函数的形参也是下标变量。换句话说,对数组元素的处理是按普通变量对待的。用数组名作函数参数时,则要求形参和相对应的实参都必须是类型相同的数组,都必须有明确的数组说明。当形参和实参二者不一致时,即会发生错误。
2) 在普通变量或下标变量作函数参数时,形参变量和实参变量是由编译系统分配的两个不同的内存单元。在函数调用时发生的值传送是把实参变量的值赋予形参变量。在用数组名作函数参数时,不是进行值的传送,即不是把实参数组的每一个元素的值都赋予形参数组的各个元素。因为实际上形参数组并不存在,编译系统不为形参数组分配内存。那么,数据的传送是如何实现的呢?在我们曾介绍过,数组名就是数组的首地址。因此在数组名作函数参数时所进行的传送只是地址的传送,也就是说把实参数组的首地址赋予形参数组名。形参数组名取得该首地址之后,也就等于有了实在的数组。实际上是形参数组和实参数组为同一数组,共同拥有一段内存空间。
上图说明了这种情形。图中设a为实参数组,类型为整型。a占有以2000为首地址的一块内存区。b为形参数组名。当发生函数调用时,进行地址传送,把实参数组a的首地址传送给形参数组名b,于是b也取得该地址2000。于是a,b两数组共同占有以2000为首地址的一段连续内存单元。从图中还可以看出a和b下标相同的元素实际上也占相同的两个内存单元(整型数组每个元素占二字节)。例如a[0]和b[0]都占用单元,当然a[0]等于b[0]。类推则有a[i]等于b[i]。
【例1】数组a中存放了一个学生5门课程的成绩,求平均成绩。
#include &stdio.h&
float aver(float a[5]){
float av,s=a[0];
for(i=1;i&5;i++)
int main(void){
float sco[5],
printf("\ninput 5 scores:\n");
for(i=0;i&5;i++)
scanf("%f",&sco[i]);
av=aver(sco);
printf("average score is %5.2f",av);
本程序首先定义了一个实型函数aver,有一个形参为实型数组a,长度为5。在函数aver中,把各元素值相加求出平均值,返回给主函数。主函数main 中首先完成数组sco的输入,然后以sco作为实参调用aver函数,函数返回值送av,最后输出av值。 从运行情况可以看出,程序实现了所要求的功能。
3) 前面已经讨论过,在变量作函数参数时,所进行的值传送是单向的。即只能从实参传向形参,不能从形参传回实参。形参的初值和实参相同,而形参的值发生改变后,实参并不变化,两者的终值是不同的。而当用数组名作函数参数时,情况则不同。由于实际上形参和实参为同一数组,因此当形参数组发生变化时,实参数组也随之变化。当然这种情况不能理解为发生了“双向”的值传递。但从实际情况来看,调用函数之后实参数组的值将由于形参数组值的变化而变化。
#include &stdio.h&
void nzp(int a[8]){
printf("\nvalues of array aare:\n");
for(i=0;i&8;i++){
if(a[i]&0)a[i]=0;
printf("%d ",a[i]);
int main(void){
int b[5],i;
printf("\ninput 5 numbers:\n");
for(i=0;i&5;i++)
scanf("%d",&b[i]);
printf("initial values of array b are:\n");
for(i=0;i&5;i++)
printf("%d ",b[i]);
printf("\nlast values of array b are:\n");
for(i=0;i&5;i++)
printf("%d ",b[i]);
本程序nzp函数的形参数组长度改为8,函数体中,for语句的循环条件也改为i&8。因此,形参数组a和实参数组b的长度不一致。编译能够通过,但从结果看,数组a的元素a[5]、a[6]、a[7]显然是无意义的。
③在函数形参表中,允许不给出形参数组的长度,或用一个变量来表示数组元素的个数。例如,可以写为:
void nzp(int a[])
void nzp( int a[], int n )
其中形参数组a没有给出长度,而由n值动态地表示数组的长度。n的值由主调函数的实参进行传送。
#include &stdio.h&
void nzp(int a[],int n){
printf("\nvalues of array a are:\n");
for(i=0;i&n;i++){
if(a[i]&0) a[i]=0;
printf("%d ",a[i]);
int main(void){
int b[5],i;
printf("\ninput 5 numbers:\n");
for(i=0;i&5;i++)
scanf("%d",&b[i]);
printf("initial values of array b are:\n");
for(i=0;i&5;i++)
printf("%d ",b[i]);
printf("\nlast values of array b are:\n");
for(i=0;i&5;i++)
printf("%d ",b[i]);
本程序nzp函数形参数组a没有给出长度,由n 动态确定该长度。在main函数中,函数调用语句为nzp(b,5),其中实参5将赋予形参n作为形参数组的长度。
④多维数组也可以作为函数的参数。在函数定义时对形参数组可以指定每一维的长度,也可省去第一维的长度。因此,以下写法都是合法的:
int MA(int a[3][10])
int MA(int a[][10])。
实际上是形参数组和实参数组为同一数组,共同使用一段内存空间。
起始地址 2000
设a为实参数组,类型为整形。a占有以2000为首地址的一块内存区。b为形参数组。当进行函数调用时,进行地址传递,把实参数组a的首地址传送给形参数组名b,于是b也取得了该地址2000.至此a、b两数组共同占用以2000为首地址的一段连续内存单元。同时,a和b中下表相同的元素实际上也占相同的内存单元(整形数组每个元素占两个字节)。
例1:有一个一维数组score,存放10个学生的成绩,求平均值。
#include&stdio.h&
#include&string.h&
#include&conio.h&
#include&stdlib.h&
float average(float array[10]){
float aver,sum=array[0];
for(i=1;i&10;i++)
sum=sum+array[i];
aver=sum/10;
float score[10],
printf("input 10 score:/n");
for(i=0;i&10;i++)
scanf("%f",&score[i]);
printf("/n");
aver=average(score);
printf("average score is %5.2f/n",aver);
(1)用数组名作函数参数,应该在主调函数和被调函数中分别定义数组。
(2)实参数组与形参数组类型应一致,如不一致,结果将出错。
(3)实际上,指定被调函数中形参数组的大小是不起任何作用的,因为C编译器对形参数组大小不做检查,只是将形参数组的首地址传给形参数组。
(4)形参数组也可以不指定大小,定义数组时在数组名后跟一个空的中括号,为了在被调函数中处理数组元素的需要,可以另设一个参数,传递数组元素的个数。
例2:用参数传递数组元素的个数。
#include&stdio.h&
#include&string.h&
#include&conio.h&
#include&stdlib.h&
float average(float array[],int n){
float aver,sum=array[0];
for(i=1;i&n;i++)
sum=sum+array[i];
aver=sum/n;
float score1[5]={98.5,97,91.5,60,55};
float score2[10]={67.5,89.5,99,69.5,77,89.5,76.5,54,60,99.5};
printf("the average of class A is %6.2f/n",average(score1,5));
printf("the average of class B is %6.2f/n",average(score2,10));
多维数组做函数的参数
当多维数组中元素做函数参数时,与一维数组元素做函数实参是相同的,这里讨论多维数组名做函数的参数。以二维数组为例:
二维数组名做函数参数时,形参的语法形式是:
类型说明符 形参名[ ][常量表达式M]
形参数组可以省略一维的长度。
例如:int array[ ][10]
由于实参代表了数组名,是"地址传递",二维数组在内存中是按行优先存储,并不真正区分行与列,在形参中,就必须指明列的个数,才能保证实参数组与形参数组中的数据一一对应,因此,形参数组中第二维的长度是不能省略的。
调用函数时,与形参数组相对应的实参数组必须也是一个二维数组,而且它的第二维的长度与形参数组的第二维的长度必须相等。
以上是云栖社区小编为您精心准备的的内容,在云栖社区的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索数组
c语言传递数组参数、c语言数组当参数传递、c语言传递数组、c语言传递二维数组、c语言函数传递数组,以便于您获取更多的相关知识。
弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率
40+云计算产品,6个月免费体验
稳定可靠、可弹性伸缩的在线数据库服务,全球最受欢迎的开源数据库之一
云服务器9.9元/月,大学必备
云栖社区(yq.aliyun.com)为您免费提供相关信息,包括
,所有相关内容均不代表云栖社区的意见!

我要回帖

更多关于 对象数组调用构造函数 的文章

 

随机推荐