标签:值传递 end font 空间 1.4 形参与实参 类型 [1] bsp
1.将变量名作为形参和实参
在这种情况下传给形参的是变量的值。传递是单向的,即如果在执行函数期间形参的值发生变化,并不传回给实参,这就是值传递方式。因为在调用函数期间,形参和实参不是同一个存储单元。
int main(){
void swap(int,int);//参数为整型变量
int i=3,j=4;
cout<<"i="<<i<<",j="<<j<<endl;
swap(i,j);//变量名
cout<<"i="<<i<<",j="<<j<<endl;
system("PAUSE");
return 0;
}
void swap(int a,int b){//形参为整型变量
int temp;
temp=a;
a=b;
b=temp;
}
结果:
i=3,j=4
i=3,j=4
可以发现,执行函数swap后,形参a和b的改变不会影响实参i和j的值。
2.传递变量指针
形参是指针变量,实参是一个变量的地址,调用函数时,形参(指针变量)指向实参变量单元。
int main(){
void swap(int*,int*);//参数为整型指针变量
int i=3,j=4;
cout<<"i="<<i<<",j="<<j<<endl;
swap(&i,&j);//变量地址
cout<<"i="<<i<<",j="<<j<<endl;
system("PAUSE");
return 0;
}
void swap(int *p1,int *p2){//形参为整型指针变量
int temp;
temp=*p1;
*p1=*p2;
*p2=temp;
}
结果:
i=3,j=4
i=4,j=3
调用函数时把变量i和j的地址传送给形参p1和p2,因此*p1和i为同一内存单元,*p2和j是同一内存单元。
这种方式还是“值传递”,只不过实参的值是变量的地址而已。而在函数中改变的不是实参的值(即地址,这种改变也影响不到实参),而是实参地址所指向的变量的值。
3.“引用形参”
int main(){
void swap(int&,int&);//参数为整型变量的引用
int i=3,j=4;
cout<<"i="<<i<<",j="<<j<<endl;
swap(i,j);//变量名
cout<<"i="<<i<<",j="<<j<<endl;
system("PAUSE");
return 0;
}
void swap(int &a,int &b){//形参为引用类型
int temp;
temp=a;
a=b;
b=temp;
}
结果:
i=3,j=4
i=4,j=3
当main函数调用swap函数时,由实参把变量名传给形参。i的名字传给引用变量a,j的名字传给引用变量b。此时a和b就分别与i,j占用同一内存空间。这种把实参地址传递到形参,使形参的地址取实参的地址,从而使形参与实参共享同一单元的方式,就是地址传递方式。
这里要说明的是,
[1]方式2传递指针变量要另外开辟内存单元,其内容为地址;而方式3引用不是一个独立的变量,不单独占内存单元。
[2]方式3中,main函数调用swap函数时,实参不必用函数的地址(即&i,&j),而直接使用变量名。系统向形参传递的是实参的地址而不是实参的值。
标签:值传递 end font 空间 1.4 形参与实参 类型 [1] bsp
原文地址:http://www.cnblogs.com/chenduzizhong/p/6032518.html