【C/C++】传值调用和传地址调用,一次就会

1. 传值和传地址调用的本质

记住一句话:当函数接收到任何参数时,都会对参数本身做一次复制。

之所以会产生理解上的歧义,是因为混淆了指针指针所指向的内容

传值调用:

很好理解,函数会新建一个变量,然后将参数变量的值赋值给新的变量,也就是说复制了传入的变量的值

传地址调用:

实际上复制了传入的指针的值【一个long int类型的值,含义是某个变量在内存中的位置,我们把这个int值叫做内存地址】
创建了新的和原本指针的值一样的指针变量,将值复制出来的值赋值给了新的指针变量
所以也是复制了传入的变量的值
可以看出,传值调用和传地址调用本质上是一致的。

2. 应用场景

所以只需要记住下面两个原则,就知道什么时候使用哪种类型的传参方式:

传值调用:
  • 函数中只需要使用参数的值,而不需要对参数的值进行修改。也就是不需要修改值,用传值调用
传地址调用:
  • 函数中会对参数原本变量的值进行修改,也就是需要修改原本的值,用传地址调用
  • 传入结构体/足够庞大,复制整个结构体/太过浪费时间。传地址调用只会传递指向原结构体/的指针,所以没有复制结构体/的开销。
备注

c++还有引用的概念,实际上就是传地址调用的语法糖,简化了显式标明指针的过程。java/python等语言中,所有的传入都是传地址调用,因为屏蔽了直接操作指针,所以是安全的。