浅谈传值调用和传地址调用

118 阅读1分钟

传值和传地址调用的本质

当函数接收到任何参数时,都会对参数本身做一次复制。 传值调用很好理解,函数会新建一个变量,将参数变量的值赋值给新的变量。 传地址调用实际上复制了传入的指针参数的值(一个int值,含义是某个变量在内存中的位置,我们把这个int值叫做内存地址),创建了新的指针变量,将值复制出来的值赋值给了新的指针变量。 可以看出,传值调用和传地址调用是高度一致的。只要理解了这个就容易得出如下一些结论。

应用场景

传值调用:

  1. 函数中只需要使用参数的值,而不需要对参数的值进行修改。

传地址调用:

  1. 函数中会对参数原本变量的值进行修改
  2. 结构体/块足够庞大,复制整个结构体/块太过浪费时间

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