您的位置:首页-> 资讯中心-> .net技术-> .net-> 浅谈C++函数的参数

.net

.net

本类阅读TOP10

·C语言的lex和yacc工具说明
·C/C++语言中指向函数的指针
·C语言库函数(S类字母) - 3
·C语言库函数(I类字母)
·(新手篇)C++Builder 6操作MS SQL Server数据库的SQL集锦
·Unix编程/应用问答中文版 ---20.shell script问题
·Unix编程/应用问答中文版 ---8.Solaris内核编程相关问题
·jsp文件操作之读取篇
·C++Builder5.0调用SQLSERVER7.0驱动编程
·C++ Builder中,sql server在客户端调用存储过程向服务器端备份数据库

精品推荐
浅谈C++函数的参数

加入时间:2005-2-22 快乐下载

函数参数的求值顺序 

当一个函数带有多个参数时,C++语言没有规定在函数调用时实参的求值顺序。而编译
器根据对代码进行优化的需要自行规定对实参的求值顺序。有的编译器规定自左至右,
有的编译器规定自右至左,这种对求值顺序的不同规定,对一般参数来讲没有影响。但
是,如果实参表达式中带有副作用的运算符时,就有可能产生由于求值顺序不同而造成
了二义性。例如:int z = add_int(++x, x+y);,这样,在不同的编译器就有可能生产
不同的结果。 

设置参数的默认值 

在C++语言中,允许在函数的说明或定义时给一个或多个参数指定默认值。但是,要求在
一个指定了默认值的参数的右边,不能出现没有指定默认值的参数。例如: 

int add_int(int x, int 10); 

在上述对函数add_int()的说明中,对该函数的最右边的一个参数指定了默认值。 

在函数调用时,编译器按从左至右的顺序将实参与形参结合,当实参的数目不足时,编译
器将按同样的顺序用说明中或定义中的默认值来补足所缺少的实参。例如,如有下列的函
数调用表达式: 

add_int(15) 

它将与下列调用表达式: 

add_int(15, 10) 

是等价的。 

在给某个参数指定默认值是,不仅可以是一个数值,而且还可以是任意复杂的表达式。 

使用数组作函数参数 

数组作函数参数可以分为如下三种情况:(这三种情况的结果相同,只是所采用的调用
机制不同) 

1. 形参和实参都用数组 

调用函数的实参用数组名,被调用函数的形参用数组,这种调用的机制是形参和实参共
用内存中的同一个数组。因此,在被调用函数中改变了数组中某个无素的值,对调用函
数该数组的该元素值也被改变,因为它们是共用同一个数组。 

2. 形参和实参都用对应数组的指针 

在C++中,数组名被规定为是一个指针,该指针便是指向该数组的首元素的指针,国为
它的值是该数组首元素的地址值,因此,数组名是一个常量指针。 

实际中,形参和实参一个用指针,另一个用数组也是可以的。在使用指针时可以用数组
名,也可以用另外定义的指向数组的指针。 

3. 实参用数组名形参用引用 

如何对数组类型使用引用方式,这里先做如下说明:先用类型定义语句定义一个int型的
数组类型,如下所示: 

typedef int array[8]; 

然后,使用array来定义数组和引用。 

示例: 

#include <iostream.h> 
typedef int array[8]; 
int a[8] = {1, 3, 5, 7, 9, 11, 13}; 
void fun(array &b, int n) 

for(int i=0; i<n-1; i++) 
b[7]+=b[i]; 


void main() 

int m=8; 
fun(a, m); 
cout<<a[7]<<endl; 


该程序中,在fun()函数中,使用了引用作形参,调用时所对应的实参应该是一个数组
名,这里的引用是给数组起个别名。在fun()函数中对数组b的操作,就相当于b所引用
数组a的操作。在C++中,常用这种调用方式。 




相关文章

相关软件