当前位置:首页 » 编程语言 » c语言参数变化
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

c语言参数变化

发布时间: 2023-06-16 08:52:05

c语言,参数处理的方式

C语言中函数参数的传递有:值传递、地址传递、引用传递这三种形式。

值传递:作为参数的变量,传递给函数执行后,自己的变量值是不变的。它(实参)仅仅只是把值赋给了形参,自己实际上是没有参与函数运算的,参与的是形参,这个就是参数的值传递。

地址传递:即采用指针方式,地址传递跟值传递没什么不同,值传递是把变量的值传递给形参去参与函数运算,而地址传递则把变量的地址传递给形参去参与函数运算。当然,如果函数改变了变量地址的值,实参的值也会变化的。

引用传递:引用传递的调用方式与值传递一样的,但形参则引用了实参,在函数里头操作的是实参,而不是像上面两种操作形参那样。传引用相当于给原来变量起了另一个名字而已,这样函数可以直接修改实参的值了。

㈡ 在c语言中怎样使形参值改变实参值也跟着改变

在C里面 是无法做到形参改变 实参值同步改变的。
只能通过传地址的方式
即参数类型为指针
这样 形参指向空间修改,可以使得实参指向空间同步修改,因为是同一块内存区域。

另外,在C++中,可以通过引用传参,来实现你说的目的。

㈢ c语言中函数可否改变参数值

#include
void
foo(int
x,
int
y,
int
z)
{
printf("x
=
%d
at
[%x]n",
x,
&x);
printf("y
=
%d
at
[%x]n",
y,
&y);
printf("z
=
%d
at
[%x]n",
z,
&z);
}
int
main(int
argc,
char
*argv[])
{
foo(100,
200,
300);
return
0;
}
运行结果:
x
=
100
at
[bfe28760]
y
=
200
at
[bfe28764]
z
=
300
at
[bfe28768]
c程序栈底为高地址,栈顶为低地址,因此上面的实例可以说明函数参数入栈顺序的确是从右至左的。可到底为什么呢?查了一直些文献得知,参数入栈顺序是和具体编译器实现相关的。比如,pascal语言中参数就是从左到右入栈的,有些语言中还可以通过修饰符进行指定,如visual
c++.即然两种方式都可以,为什么c语言要选择从右至左呢?
进一步发现,pascal语言不支持可变长参数,而c语言支持这种特色,正是这个原因使得c语言函数参数入栈顺序为从右至左。具体原因为:c方式参数入栈顺序(从右至左)的好处就是可以动态变化参数个数。通过栈堆分析可知,自左向右的入栈方式,最前面的参数被压在栈底。除非知道参数个数,否则是无法通过栈指针的相对位移求得最左边的参数。这样就变成了左边参数的个数不确定,正好和动态参数个数的方向相反。
因此,c语言函数参数采用自右向左的入栈顺序,主要原因是为了支持可变长参数形式。换句话说,如果不支持这个特色,c语言完全和pascal一样,采用自左向右的参数入栈方式

㈣ C语言中,简单变量作为参数,调用函数数后,什么时候值改变,什么时候不变

常规类型(int、double、float、char等)的都不会变
指针类型(int*、double*、float*,char*等)的都会变
数组类型(int[]、double[]、float[],char[])的也都会变
类也会变(c++范畴)
总而言之:参数指向值的,都不会变;参数指向地址的都会变(数组也是指向地址的。可以理解为本质也是指针)