//1. 值传递
void mySwap01(int a, int b) {
int temp = a;
a = b;
b = temp;
}
//2. 地址传递
void mySwap02(int* a, int* b) {
int temp = *a;
*a = *b;
*b = temp;
}
//3. 引用传递
void mySwap03(int& a, int& b) {
int temp = a;
a = b;
b = temp;
}
int main() {
int a = 10;
int b = 20;
mySwap01(a, b);
cout << "a:" << a << " b:" << b << endl;
mySwap02(&a, &b);
cout << "a:" << a << " b:" << b << endl;
mySwap03(a, b);
cout << "a:" << a << " b:" << b << endl;
system("pause");
return 0;
}
结果
值传递并不改变实参的大小,地址传递和引用传递均改变地址大小。
原因是什么?是因为考别构造。
1.函数传参的时候,会对形参拷贝一份,放在栈区,实际操作的是栈区的变量(拷贝),函数运行完毕时。编译器会释放栈区所占用的空间,所以并不改变实参大小。
2.地址传递的时候,传入的是实参地址,根据地址对实参操作。
3.引用构造,函数传参的实收标记引用的变量,引用就是对原参数地址操作,因为引用名和原变量名指向的是同一块地址,所以相当于地址传递。(引用的本质就是指针常量。)