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

c语言中函数可否改变参数值,第1张

#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一样,采用自左向右的参数入栈方式

形参在函数定义时表示的一种占位符,实参就是里面存有实际变量值或者常量,函数调用时,实参值会自动传递给形参变量。指针比较复杂了。是变量的地址,如果参数类型是指针类型,则必须把实参变量的地址传递过去。当然在函数内也是间接引用实参变量的。

比如

void f(int p) //形参是指针类型变量

下面是调用形式

f(&a); //调用函数,实参是变量a的地址。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/11670925.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-17
下一篇 2023-05-17

发表评论

登录后才能评论

评论列表(0条)

保存