//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.引用构造,函数传参的实收标记引用的变量,引用就是对原参数地址操作,因为引用名和原变量名指向的是同一块地址,所以相当于地址传递。(引用的本质就是指针常量。)