1. 传值和传地址调用的本质
记住一句话:当函数接收到任何参数时,都会对参数本身做一次复制。
之所以会产生理解上的歧义,是因为混淆了指针和指针所指向的内容。
传值调用:
很好理解,函数会新建一个变量,然后将参数变量的值赋值给新的变量,也就是说复制了传入的变量的值。
传地址调用:
实际上复制了传入的指针的值【一个long int 类型的值,含义是某个变量在内存中的位置,我们把这个int 值叫做内存地址】 创建了新的和原本指针的值一样的指针变量,将值复制出来的值赋值给了新的指针变量 所以也是复制了传入的变量的值。 可以看出,传值调用和传地址调用本质上是一致的。
2. 应用场景
所以只需要记住下面两个原则,就知道什么时候使用哪种类型的传参方式:
传值调用:
- 函数中只需要使用参数的值,而不需要对参数的值进行修改。也就是不需要修改值,用传值调用。
传地址调用:
- 函数中会对参数原本变量的值进行修改,也就是需要修改原本的值,用传地址调用。
- 传入
结构体 /块 足够庞大,复制整个结构体 /块 太过浪费时间。传地址调用只会传递指向原结构体 /块 的指针,所以没有复制结构体 /块 的开销。
备注
c++ 还有引用的概念,实际上就是传地址调用的语法糖,简化了显式标明指针的过程。java /python 等语言中,所有的传入都是传地址调用,因为屏蔽了直接操作指针,所以是安全的。
|