c语言数组函数参数怎么用 c语音数组函数

c语言中用函数做参数怎么用数组元素就是下标变量,它与普通变量并无区别 。因此它作为函数实参使用与普通变量是完全相同的,在发生函数调用时,把作为实参的数组元素的值传送给形参 , 实现单向的值传送 。【例5-4】说明了这种情况 。
【例8-7】判别一个整数数组中各元素的值,若大于0 则输出该值,若小于等于0则输出0值 。编程如下:#include stdio.hvoid nzp(int v){if(v0)printf("%d ",v);elseprintf("%d ",0);}int main(void){int a[5],i;printf("input 5 numbers\n");for(i=0;i5;i){scanf("%d",a[i]);nzp(a[i]);}return 0;}
本程序中首先定义一个无返回值函数nzp , 并说明其形参v为整型变量 。在函数体中根据v值输出相应的结果 。在main函数中用一个for语句输入数组各元素,每输入一个就以该元素作实参调用一次nzp函数,即把a[i]的值传送给形参v,供nzp函数使用 。
数组名作为函数参数
用数组名作函数参数与用数组元素作实参有几点不同 。
1) 用数组元素作实参时,只要数组类型和函数的形参变量的类型一致,那么作为下标变量的数组元素的类型也和函数形参变量的类型是一致的 。因此,并不要求函数的形参也是下标变量 。换句话说,对数组元素的处理是按普通变量对待的 。用数组名作函数参数时,则要求形参和相对应的实参都必须是类型相同的数组,都必须有明确的数组说明 。当形参和实参二者不一致时,即会发生错误 。
2) 在普通变量或下标变量作函数参数时,形参变量和实参变量是由编译系统分配的两个不同的内存单元 。在函数调用时发生的值传送是把实参变量的值赋予形参变量 。在用数组名作函数参数时,不是进行值的传送 , 即不是把实参数组的每一个元素的值都赋予形参数组的各个元素 。因为实际上形参数组并不存在,编译系统不为形参数组分配内存 。那么,数据的传送是如何实现的呢?在我们曾介绍过,数组名就是数组的首地址 。因此在数组名作函数参数时所进行的传送只是地址的传送 , 也就是说把实参数组的首地址赋予形参数组名 。形参数组名取得该首地址之后,也就等于有了实在的数组 。实际上是形参数组和实参数组为同一数组,共同拥有一段内存空间 。
上图说明了这种情形 。图中设a为实参数组,类型为整型 。a占有以2000为首地址的一块内存区 。b为形参数组名 。当发生函数调用时,进行地址传送,把实参数组a的首地址传送给形参数组名b , 于是b也取得该地址2000 。于是a,b两数组共同占有以2000为首地址的一段连续内存单元 。从图中还可以看出a和b下标相同的元素实际上也占相同的两个内存单元(整型数组每个元素占二字节) 。例如a[0]和b[0]都占用2000和2001单元,当然a[0]等于b[0] 。类推则有a[i]等于b[i] 。
【例8-8】数组a中存放了一个学生5门课程的成绩 , 求平均成绩 。#include stdio.hfloat aver(float a[5]){int i;float av,s=a[0];for(i=1;i5;i)s=s a[i];av=s/5;return av;}int main(void){float sco[5],av;int i;printf("\ninput 5 scores:\n");for(i=0;i5;i)scanf("%f",sco[i]);av=aver(sco);printf("average score is %5.2f",av);return 0;}
本程序首先定义了一个实型函数aver,有一个形参为实型数组a,长度为5 。在函数aver中 , 把各元素值相加求出平均值,返回给主函数 。主函数main 中首先完成数组sco的输入,然后以sco作为实参调用aver函数,函数返回值送av , 最后输出av值 。从运行情况可以看出,程序实现了所要求的功能 。
3) 前面已经讨论过,在变量作函数参数时 , 所进行的值传送是单向的 。即只能从实参传向形参,不能从形参传回实参 。形参的初值和实参相同,而形参的值发生改变后,实参并不变化 , 两者的终值是不同的 。而当用数组名作函数参数时,情况则不同 。由于实际上形参和实参为同一数组,因此当形参数组发生变化时,实参数组也随之变化 。当然这种情况不能理解为发生了“双向”的值传递 。但从实际情况来看,调用函数之后实参数组的值将由于形参数组值的变化而变化 。为了说明这种情况,把【例5.4】改为【例5.6】的形式 。
【例8-9】题目同【例8.7】 。改用数组名作函数参数 。#include stdio.hvoid nzp(int a[5]){int i;printf("\nvalues of array a are:\n");for(i=0;i5;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;i5;i)scanf("%d",b[i]);printf("initial values of array b are:\n");for(i=0;i5;i)printf("%d ",b[i]);nzp(b);printf("\nlast values of array b are:\n");for(i=0;i5;i)printf("%d ",b[i]);return 0;}
本程序中函数nzp的形参为整数组a,长度为5 。主函数中实参数组b也为整型,长度也为5 。在主函数中首先输入数组b的值,然后输出数组b的初始值 。然后以数组名b为实参调用nzp函数 。在nzp中,按要求把负值单元清0,并输出形参数组a的值 。返回主函数之后,再次输出数组b的值 。从运行结果可以看出,数组b的初值和终值是不同的,数组b的终值和数组a是相同的 。这说明实参形参为同一数组,它们的值同时得以改变 。
用数组名作为函数参数时还应注意以下几点:
①形参数组和实参数组的类型必须一致 , 否则将引起错误 。
②形参数组和实参数组的长度可以不相同,因为在调用时,只传送首地址而不检查形参数组的长度 。当形参数组的长度与实参数组不一致时,虽不至于出现语法错误(编译能通过),但程序执行结果将与实际不符 , 这是应予以注意的 。
【例8.10】如把例8.9修改如下:#include stdio.hvoid nzp(int a[8]){int i;printf("\nvalues of array aare:\n");for(i=0;i8;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;i5;i)scanf("%d",b[i]);printf("initial values of array b are:\n");for(i=0;i5;i)printf("%d ",b[i]);nzp(b);printf("\nlast values of array b are:\n");for(i=0;i5;i)printf("%d ",b[i]);return 0;}
本程序与【例8.9】程序比,nzp函数的形参数组长度改为8,函数体中,for语句的循环条件也改为i8 。因此,形参数组a和实参数组b的长度不一致 。编译能够通过,但从结果看 , 数组a的元素a[5]、a[6]、a[7]显然是无意义的 。
③在函数形参表中,允许不给出形参数组的长度,或用一个变量来表示数组元素的个数 。例如,可以写为:
void nzp(int a[])
或写为
void nzp( int a[], int n )
其中形参数组a没有给出长度,而由n值动态地表示数组的长度 。n的值由主调函数的实参进行传送 。由此 , 【例8-10】又可改为【例8-11】的形式 。
【c语言数组函数参数怎么用 c语音数组函数】【例8-11】复制纯文本新窗口
#include stdio.hvoid nzp(int a[],int n){int i;printf("\nvalues of array a are:\n");for(i=0;in;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;i5;i)scanf("%d",b[i]);printf("initial values of array b are:\n");for(i=0;i5;i)printf("%d ",b[i]);nzp(b,5);printf("\nlast values of array b are:\n");for(i=0;i5;i)printf("%d ",b[i]);return 0;}
C语言中自定义的函数中有数组,应该如何运用该函数方法
有2
将该数组定义为全局变量,即:
int
g_arr;
void
fun()
{...}
void
main()
{...}
2.将该数组作为函数参数传递到自定义函数里,即:
void
fun(int
arr[])
{...}
void
main()
{
int
arr[10];
fun(arr);
}
c语言怎么将数组作为函数参数传入?一维数组的元素作为函数实参 , 与同类型的简单变量作为实参一样 , 是单向的值传递,即数组元素的值传给形参,从而形参是改变不影响实参
数组名代表着整个数组的地址,如果一维数组的名字作为函数实参,传递的是整个数组,即形参数组和实参数组完全相同,是存放在同一存储空间的同一个数组 。这样形参数组
修改时 , 实参数组也同时被修改了 。形参数组的元素个数可以省略 。
#includestdio.h
//数组作为函数参数,可以省略元素个数
//数组作为函数参数 , 传递是整个数组的地址 , 修改了函数形参数组元素的值 , 会影响到外面的实参数组
void change(int array[])
{
printf("array ==%p\n",array);
array[0] = 100;
}
int main()
{
int ages[6] = {10,11,13,15,11,18};
printf("array ==%p\n",ages);
change(ages);
printf("%d\n",ages[0]);
return 0;
}
输出结果为:array ==0x7fff5be26c00
array ==0x7fff5be26c00
100
c语言函数怎么调用数组部分一、数组可定义为全局变量c语言数组函数参数怎么用,函数直接调用 。
二、数组可定义为局部变量,再通过参数传递到函数中调用(实参传数组名,表示数组首地址,也可通过指针或数组名 数字来传递数组局部地址) 。
三、main函数想要调用函数返回的数组,可用static定义静态变量或malloc定义动态数组(字符串常量也可返回使用 , 但局部变量,在函数调用结束会被释放,不能作为返回地址使用) 。
下面是演示代码c语言数组函数参数怎么用:
#include stdio.h
#include string.h
#include malloc.h
char str1[]="我是全局变量数组";
char *fun0(char str2[]);
char *fun1();
char *fun2();
int main()
{
char *str3=NULL,*str4=NULL,*str5=NULL;
char str2[]="我是main函数的局部数组变量";
str3=fun0(str2);
printf("str3:%s,fun函数调用结束 , 我的地址依然可以使用\n",str3);
str4=fun1();
printf("str4:%s,fun函数调用结束,我的地址依然可以使用\n",str4);
str5=fun2();
printf("str5:%s,fun函数调用结束,函数结束不会自动释放\n",str5);
free(str5);
return 0;
}
char *fun0(char s[])
{
static char str3[]="我是fun函数申明的静态数组变量";
printf("str1:%s,fun函数可以直接调用\n",str1);
printf("str2:%s,fun函数通过参数将我的地址传进来\n",s);
return str3;
}
char *fun1()
{
char *str4="我是fun1函数的字符串常量";
return str4;
}
char *fun2()
{
int len;
char sTemp[]="这是一个临时数组 , 之后用于给mallc申请的地址传值,传递内容为:(我是fun函数通过mallic申请的数组)";
char *str5=NULL;
len=strlen(sTemp 63);
str5=(char *)malloc(sizeof(char)*len 1);
if(!str5)return NULL;
strcpy(str5,sTemp 63);
str5[len-2]=0;
return str5;
}
c语言中怎么用二维数组作为函数参数C语言中
指针做函数参数传递二维数组有两种基本方法:1、传递“数组指针”pre
t="code"
l="cpp"#include
stdio.h
void
output(
int
(*pa)[3],
int
n
)//这个函数只能输出n行3列的二维数组
{
int
i,j;
for(
i=0;in;i
){
for(
j=0;j3;j
)
printf("%d
",
pa[i][j]
);
printf("\n");
}
}
void
main()
{
int
a[2][3]={
{1,2,3},
{4,5,6}
};
output(a,2);
}2、传递“指针数组”
先将二维数组的行指针存储到一个指针数组中,再将指针数组传递到子函数中去 。pre
t="code"
l="cpp"#include
stdio.h
void
output(
int
*pa[],
int
row,int
col
)
//这个函数更通用,但调用前,要做好准备工作 。
{
int
i,j;
for(
i=0;irow;i
){
for(
j=0;jcol;j
)
printf("%d
",
pa[i][j]
);
printf("\n");
}
}
void
main()
{
int
a[2][3]={
{1,2,3},
{4,5,6}
};
int
i;
int
*pa[2];
for(
i=0;i2;i
)
pa[i]=a[i];
output(pa,
2,
3);
}
C语言中,数组做函数参数如何才能按值传递?传数组给一个函数,数组类型自动转换为指针类型,因而传的实际是地址 。
void func(int array[10])
void func(int array[])
void func(int *array)
所以以上三种函数声明完全等同 。
实际情况是,数组做参数,完全无法按值传递 。这是由C/C函数的实现机制决定的 。
下一个问题是:为什么偏要按值传递呢?当要在一个函数内使用一个数组时,传一个指针进去不就行了?只要能访问到我们所要的数据并对其进行操作,何苦钻牛角尖 。
关于c语言数组函数参数怎么用和c语音数组函数的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。

    推荐阅读