数组作为形参和实参之间的值传递
展开全部
数组作为形参只是一种形式,其实和对应的数据类型指针等价
数组作为实参传递的是地址,并不会传递数组长度信息
在形参中声明数组的大小并没有任何意义,编译器不会解释这个大小,仍然按照指针来处理它。
形参出现在函数定义中,在整个函数体内都可以使用, 离开该函数则不能使用。
实参出现在主调函数中,进入被调函数后,实参变量也不能使用。
形参和实参的功能是作数据传送。发生函数调用时, 主调函数把实参的值传送给被调函数的形参从而实现主调函数向被调函数的数据传送。
1.形参变量只有在被调用时才分配内存单元,在调用结束时, 即刻释放所分配的内存单元。因此,形参只有在函数内部有效。 函数调用结束返回主调函数后则不能再使用该形参变量。
2.实参可以是常量、变量、表达式、函数等, 无论实参是何种类型的量,在进行函数调用时,它们都必须具有确定的值, 以便把这些值传送给形参。 因此应预先用赋值,输入等办法使实参获得确定值。
3.实参和形参在数量上,类型上,顺序上应严格一致, 否则会发生“类型不匹配”的错误。
4.函数调用中发生的数据传送是单向的。 即只能把实参的值传送给形参,而不能把形参的值反向地传送给实参。 因此在函数调用过程中,形参的值发生改变,而实参中的值不会变化。
5.当形参和实参不是指针类型时,在该函数运行时,形参和实参是不同的变量,他们在内存中位于不同的位置,形参将实参的内容复制一份,在该函数运行结束的时候形参被释放,而实参内容不会改变。
而如果函数的参数是指针类型变量,在调用该函数的过程中,传给函数的是实参的地址,在函数体内部使用的也是实参的地址,即使用的就是实参本身。所以在函数体内部可以改变实参的值。
数组作为实参传递的是地址,并不会传递数组长度信息
在形参中声明数组的大小并没有任何意义,编译器不会解释这个大小,仍然按照指针来处理它。
形参出现在函数定义中,在整个函数体内都可以使用, 离开该函数则不能使用。
实参出现在主调函数中,进入被调函数后,实参变量也不能使用。
形参和实参的功能是作数据传送。发生函数调用时, 主调函数把实参的值传送给被调函数的形参从而实现主调函数向被调函数的数据传送。
1.形参变量只有在被调用时才分配内存单元,在调用结束时, 即刻释放所分配的内存单元。因此,形参只有在函数内部有效。 函数调用结束返回主调函数后则不能再使用该形参变量。
2.实参可以是常量、变量、表达式、函数等, 无论实参是何种类型的量,在进行函数调用时,它们都必须具有确定的值, 以便把这些值传送给形参。 因此应预先用赋值,输入等办法使实参获得确定值。
3.实参和形参在数量上,类型上,顺序上应严格一致, 否则会发生“类型不匹配”的错误。
4.函数调用中发生的数据传送是单向的。 即只能把实参的值传送给形参,而不能把形参的值反向地传送给实参。 因此在函数调用过程中,形参的值发生改变,而实参中的值不会变化。
5.当形参和实参不是指针类型时,在该函数运行时,形参和实参是不同的变量,他们在内存中位于不同的位置,形参将实参的内容复制一份,在该函数运行结束的时候形参被释放,而实参内容不会改变。
而如果函数的参数是指针类型变量,在调用该函数的过程中,传给函数的是实参的地址,在函数体内部使用的也是实参的地址,即使用的就是实参本身。所以在函数体内部可以改变实参的值。
展开全部
定义一个接收2维数组的函数void pre_fect(int [][5],int n) 还可以接收复合文字的数组,void pre_fect((int[]){{1,2,3,4,5,6},6}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你所说的是值传递,而不是指针传递
函数声明:void fun(int a);
已知b[5]={1,2,3,4,5};
需要传递b[2]给函数的话就可以调用函数fun(b[2]);
函数声明:void fun(int a);
已知b[5]={1,2,3,4,5};
需要传递b[2]给函数的话就可以调用函数fun(b[2]);
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
数组作函数的参数时,有四种传输方法。
比如: 一、void key(uchar x[],uchar n)
main()
{
uchar a[]={0,1,2,3,4,5,6,7,8,9};
key(a,10);
}
二、main()
{
uchar a[]={};
uchar *p;
p=a;
key(p,10);
}
void key(uchar *p,uchar n)
三、main()
{
uchar a[]={};
key(a,10);
}
四、main()
{
uchar a[]={};
uchar *p
p=a;
key(p,10);
}
我就知道四种而已,参数之间都是位置进行传递的。在传递时系统会从右至左计算实参的值然后按照对应位置传递给形参,然后执行调用函数。并得到结果。
俺只知道这么多,真是见笑了。自已学的不太精。找高手解答吧。
比如: 一、void key(uchar x[],uchar n)
main()
{
uchar a[]={0,1,2,3,4,5,6,7,8,9};
key(a,10);
}
二、main()
{
uchar a[]={};
uchar *p;
p=a;
key(p,10);
}
void key(uchar *p,uchar n)
三、main()
{
uchar a[]={};
key(a,10);
}
四、main()
{
uchar a[]={};
uchar *p
p=a;
key(p,10);
}
我就知道四种而已,参数之间都是位置进行传递的。在传递时系统会从右至左计算实参的值然后按照对应位置传递给形参,然后执行调用函数。并得到结果。
俺只知道这么多,真是见笑了。自已学的不太精。找高手解答吧。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询