扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
形参只是实参的一个副本,即拷贝,它们不能公用存储单元。
我们提供的服务有:网站设计制作、成都网站设计、微信公众号开发、网站优化、网站认证、仙居ssl等。为超过千家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的仙居网站制作公司
参数之间的传递分为数值传递与地址传递,如果是数值传递时,各自占用不同的内存单元,如果是地址传递时,共用同一段内存单元。
函数调用时,主调函数把实参的值传送给被调函数的形参从而实现主调函数向被调函数的数据传送。 形参变量只有在被调用时才分配内存单元,在调用结束时,即刻释放所分配的回内存单元。
形参只是实参的一个副本,即拷贝,它们不能公用存储单元,不占相同的空间。
扩展资料:
函数调用过程
1、函数的形参列于函数声明中,在函数定义的函数体内使用。在未出现函数调用时,形参不占内存中的存储单元;当函数调用时,形参(任何种类的)是一类将被填充的空白或是占位符。
2、将实参的值传递给形参。当函数被调用时,实参列在函数名后面的括号里。执行函数调用时,实参被传递给形参。
3、在执行函数期间,由于形参已经有值,可以利用其进行相关运算。
4、通过return语句将函数值带回到主调函数。
5、调用结束,形参单元被释放。实参单元仍保留并维持原值(值传递)。
参考资料来源:百度百科-形式参数
参考资料来源:百度百科-实际参数
答案肯定的——形参和实参可以完全一样。
在程序执行的过程中,实参的作用域是主函数,只要程序没有停止,实参一直有效;
形参是定义函数是引入的参数,系统只在该函数被调用时分配临时内存,当自定义函数执行完后,用于临时储存形参的空间将被释放。
所以即使形参和实参的类型,名字完全一样,系统也能够把它们区分开。即可以完全一样。
注:解决这个疑问关键是要搞清楚变量作用域方面的内容。
※※※※※※※※※※※第一个问题的答复※※※※※※※※※※※※※※※
看明白了你的意思,
其实不知道你自己有没有注意到,你所尝试的方法,
如果用C语言来做的话,其实就是实现了C语言的部分面向对象的实现,
说是"部分"的原因是,这仅仅是实现了面向对象的“方法”。
如果想实现的话,准确的讲,应该不是你所说的,将"函数"作为形参,
应该是将“函数指针”作为形参。
这个在回调(CallBack)函数设计时,使用的非常多,
简单举一个例子:
#include stdlib.h
#include stdio.h
int Do1()
{
return 0;
}
int Do2(int num)
{
printf("The num is: %d\n", num);
return 0;
}
void CallBack1(void (*ptr)())//指向函数的指针作函数参数
{
(*ptr)();
}
void CallBack2(int n, int (*ptr)())//指向函数的指针作函数参数,这里第一个参数是为指向函数的指针服务的,
{ //不能写成void Caller2(int (*ptr)(int n)),这样的定义语法错误。
(*ptr)(n);
return;
}
int main()
{
CallBack1(Do1); //相当于调用Do1();
CallBack2(50, Do2); //相当于调用Do2(50);
return 0;
}
※※※※※※※※※※※第一个问题的答复※※※※※※※※※※※※※※※
※※※※※※※※※※※补充问题的答复※※※※※※※※※※※※※※※
针对你的补充问题,解答如下:
这个是可变形参的实现,准确地说,不是通过数组实现的,而是通过栈实现的。
C语言中的printf,scanf就是最常见的可变形参函数,定义一个可变形参的函数很简单,如void print(int n, ...) ,函数中对参数的处理主要是通过对栈进行操作,而c函数的实参都是自右向左压入栈的. 主要的栈操作(都是宏)有va_list,va_start ,va_arg,va_end, 定义如下:
typedef char * va_list;
#define _INTSIZEOF(n) ( (sizeof(n) + sizeof(int) - 1) ~(sizeof(int) - 1) )
#define va_start _crt_va_start
#define va_arg _crt_va_arg
#define va_end _crt_va_end
#define _crt_va_start(ap,v) ( ap = (va_list)_ADDRESSOF(v) + _INTSIZEOF(v) )
#define _crt_va_arg(ap,t) ( *(t *)((ap += _INTSIZEOF(t)) - _INTSIZEOF(t)) )
#define _crt_va_end(ap) ( ap = (va_list)0 )
va_start(ap,v):主要是获取可变参数列表的首地址,然后赋值给ap,近似ap=v+sizeof(v) (这里暂不考虑内存对齐和类型转换)
va_arg(ap,t):取得返回类型t的可变参数值, 并使ap指向下一个参数: ap += sizeof(t),这里的t是可变参数的数据类型,如int,float之类
va_end(ap):给ap初始化
va_start(ap,v) va_arg(ap,t) va_end(ap)三者合用,保证程序的健壮性.
一个使用可变形参的简单程序:
#include stdio.h
#include stdarg.h //包含va_list等定义
float sum( float first, ... ) //,...代表可变形参函数
{
float i=first,sum=0;
va_list maker; //va_list 类型数据可以保存函数的所有参数,做为一个列表一样保存
va_start(maker,first); //设置列表的起始位置
while(i!=-1.0)
{
sum+=i;
i=va_arg(maker,float); //返回maker列表的当前值,并指向列表的下一个位置
}
return sum;
}
void main(void)
{
printf( "sum is: %f\n", sum( 2.0,8.0,8.5,-1.0 ) ); //函数调用
}
※※※※※※※※※※※补充问题的答复※※※※※※※※※※※※※※※
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流