#include <iostream>
using namespace std;
//
//
void valuePass(int num) {
std::cout << "值传递****" << endl;
std::cout << "传递前:" << num << endl;
num = 100;
std::cout << "传递后:" << num << endl;
}
void importPass(int &num) {
std::cout << "引用传递****" << std::endl;
std::cout << "传递前:" << num << std::endl;
num = 100;
std::cout << "传递后:" << num << std::endl;
}
void addressPass(int *num, int *num2) {
std::cout << "地址传递****" << std::endl;
std::cout << "传递后:" << num << std::endl;
*num = 100;
std::cout << "传递后:" << num << std::endl;
int num3 = 14514;
num2 = &num3;
}
void test() {
// 这一个例子就可以很好的解释指针
int num = 2;
// 这句是在声明指针,指针的值是一个变量的地址,而*ptr 是解地址,指向地址上面的值
// 而&num 则是在引用num的地址
int *ptr = #
std::cout << num << std::endl;
std::cout << ptr << "\t" << *ptr << "\t" << &ptr << endl;
// 然后开始类推引用传递和值传递的区别
valuePass(num);
std::cout << "传递后外部值:" << num << std::endl;
// 值传递时,不影响外部数值,函数会开辟一个临时空间用于值计算
num = 2;
std::cout << "reset: num=" << num << std::endl;
importPass(num);
std::cout << "传递后外部值: " << num << std::endl;
// 地址传递,调用的时候,不需要传入目标地址,只传入目标本体就行,编译器会自动解析地址
// 在函数内,会在目标地址所代表的变量上修改数据s
num = 2;
std::cout << "reset: num=" << num << std::endl;
int num2 = 10;
addressPass(&num, &num2);
std::cout << "传递后外部值: num=" << num << "\tnum2=" << num2;
// 引用传递,函数定义需要声明,传入的是地址,即类似*p=&num,
// 函数声明,传入的值是地址,调用需传入地址,修改目标值,需要用*,解地址,从而修改目标值
// 当然本质也可以,直接num2=&num3修改传入的地址的值,但是外部值反而不会被修改
// 为什么,我个人理解,函数里面的变量都是临时变量,但是引用传递和地址传递,直接指向了地址,所以才能从地址层面修改值,
// 如果改地址,其实还是在修改临时变量,并没有修改实际地址上的实际值
}
int main() {
test();
}
输出结果
2
0x9b4f1ffb5c 2 0x9b4f1ffb50
值传递****
before:2
after:100
outsize:2
reset: num=2
地址传递****
before:2
after:100
outsize: 100
reset: num=2
引用传递****
before:0x9b4f1ffb5c
after:0x9b4f1ffb5c
outsize: num=100 num2=10