函数副本机制
1. 函数的参数的传递两种形式,传值与传地址。
函数的输入-参数,函数的输出-返回值不仅可以是int,double等等也可以是数组,结构体等等。
所谓副本机制,是指copy(拷贝)的思想,不论是传值调用还是传址调用,编译器都要为每个参数制作临时副本,或称拷贝,函数体中对参数的修改都是对副本的修改。
1.将值传递给num,num并不会改变原来的值
2.将地址传递给 *p, 会改变原来地址的值
p是一个副本,新建一个变量容纳传递过来的p的值
无论传递什么参数,函数都有副本机制
改变一个变量,需要传入变量的地址
改变一个指针变量,需要指针变量的地址
注意:函数的参数,会对数组传地址,不会有副本机制,为了节约内存,数组传递的是指针
3.return的副本机制
当执行到return语句时,return的值被复制到某个内存单元或寄存器中,其地址是由编译器来维护的,程序员无法直接访问该地址,也就是说,在函数执行完毕,相关现场被撤销前,返回的值被复制保存到了某个地方,编译器访问该位置即可知道函数的返回值。该位置即可看成是函数中返回值的副本。
注意:
(1)函数内部定义的变量,返回以后,变量就会被销毁,内存会被回收。
(2)函数返回值有副本机制,返回的时候,另外再保存一份,当获取到返回值后,原来内存的数据就被销毁了。
动态申请内存是在堆中完成的,而函数返回不会释放堆内存,但不要忘记,函数返回时,栈内存中的内容会被自动清除,因此,不要返回指向栈内存的指针。
【函数返回指针不可指向栈可以指向堆】
return 语句不可返回指向“栈内存”的“指针”或者“引用”,因为该内存在函数体结束时被自动销毁。
1.栈返回实现
输出结果:
2.在堆上开辟空间
堆可以跨函数使用,需要自己释放内存