实参
-
实际的参数,即在生命周期内的,可以说其实实参就是形参,因为每一个参数都都是在一个函数内定义的(全局变量,static除外)
-
实参出现在主调函数中,进入被调函数后,实参变量也不能使用。
形参
-
形式上的参数,由传入的实参进行初始化,生命周期在函数的调用后结束;形参和实参的功能是作数据传送。发生函数调用时, 主调函数把实参的值传送给被调函数的形参从而实现主调函数向被调函数的数据传送。
1.传递的形式;
传引用;即将形参绑定到传入的实参对象上尽量使用引用而非拷贝(拷贝大的类型或者容器对象低效) 若无需修改引用的实参,最好使用常量引用
bool is_shorter(const string &str1,const string & str2){
rerturn str1.size()>str2.size();
}传值; 传递的是实参的一个拷贝
- 指针形参
若形参前无&,则为指针形参,即是传值;实际上是这样的,传引用,系统将在函数栈,上开辟一块内存,用于存储指针,该指针指向了实参,所以修改这个指针所指向的对象会改变到实参;而传值不同,传值是把实参拷贝一份,所以形参和实参将是两个东西,互不影响!
附:
1.深拷贝:指的就是当拷贝对象中有对其他资源(如堆、文件、系统等)的引用时(引用可以是指针或引用)时,对象的另开辟一块新的资源,而不再对拷贝对象中有对其他资源的引用的指针或引用进行单纯的赋值。
2.浅拷贝:将指向对象的内存拷贝一份,因而与对象仍然有关联,此时应该注意指针空悬的问题
总结
- 形参变量只有在被调用时才分配内存单元,在调用结束时, 即刻释放所分配的内存单元。因此,形参只有在函数内部有效。 函数调用结束返回主调函数后则不能再使用该形参变量。
- 实参可以是常量、变量、表达式、函数等, 无论实参是何种类型的量,在进行函数调用时,它们都必须具有确定的值, 以便把这些值传送给形参。 因此应预先用赋值,输入等办法使实参获得确定值。
- 实参和形参在数量上,类型上,顺序上应严格一致, 否则会发生“类型不匹配”的错误。
- 函数调用中发生的数据传送是单向的。 即只能把实参的值传送给形参,而不能把形参的值反向地传送给实参。 因此在函数调用过程中,形参的值发生改变,而实参中的值不会变化。
- 当形参和实参不是指针类型时,在该函数运行时,形参和实参是不同的变量,他们在内存中位于不同的位置,形参将实参的内容复制一份,在该函数运行结束的时候形参被释放,而实参内容不会改变。
而如果函数的参数是指针类型变量,在调用该函数的过程中,传给函数的是实参的地址,在函数体内部使用的也是实参的地址,即使用的就是实参本身。所以在函数体内部可以改变实参的值。