C++ 实参和形参

来源:互联网 发布:生命一号 知乎 编辑:程序博客网 时间:2024/06/06 09:22


形参和实参的功能是作数据传送。发生函数调用时, 主调函数把实参的值传送给被调函数的形参从而实现主调函数向被调函数的数据传送。

形参出现在函数定义中,在整个函数体内都可以使用, 离开该函数则不能使用。实参出现在主调函数中,进入被调函数后,实参变量也不能使用。 每次调用函数时,都会重新创建该函数所有的形参,此时所传递的实参将会初始化对应的形参。形参的初始化与变量的初始化一样:如果形参具有非引用类型,则复制实参的值;如果形参为引用类型,则它只是实参的别名。


1.形参变量只有在被调用时才分配内存单元,在调用结束时, 即刻释放所分配的内存单元。因此,形参只有在函数内部有效。 函数调用结束返回主调函数后则不能再使用该形参变量。
2.实参可以是常量、变量、表达式、函数等, 无论实参是何种类型的量,在进搜索行函数调用时,它们都必须具有确定的值, 以便把这些值传送给形参。 因此应预先用赋值,输入等办法使实参获得确定值。

3.实参和形参在数量上,类型上,顺序上应严格一致, 否则会发生“类型不匹配”的错误。

4.函数调用中发生的数据传送是单向的。 即只能把实参的值传送给形参,而不能把形参的值反向地传送给实参。 因此在函数调用过程中,形参的值发生改变,而实参中的值不会变化。


c++中函数通常是按值传递参数。参数是传递原变量的值的一个拷贝。


a,普通变量时值传递,函数使用该变量的拷贝,不能改变原来变量的值。


b,如果是指针,是地址的一个拷贝,其实也是值传递(地址的值传递)。你不能改变原来变量(地址)的值,但能改变这个地址指向的内容,即所谓的实参被改变了。


c,如果是引用,传递的也是一个地址,不过这个地址又解析过了的,所以能直接用,不用再加*去解析(地址值传递,用时已经解析了)。改变值同指针一样,不过不能改变地址就更明显了(引用其实是一个解析了的const 指针)

d.传递数组时,函数将使用原来的数组。因为此时函数传递的是数组的地址(数组名)。将数组地址作为参数可以节省复制整个数组所需的时间和内存。



指针变量可以是用引用类型:
例如 char* p=0; char* &p2=p; 这时用p2就和用p一样了,表达的意思就是作为参数传递,你能改变参数的值了,就是能改变实参指针的地址了。而且函数有时需要传参数改变地址,参数就可以 char* &p2这样子(也可以char** 不过要解析地址后用)。然后就可以在函数里面修改地址,然后原来那个指针(即指针的值(地址))就被改变了。其实原理和我上面说的一样。不过有多重*


1、值传递

    实参是变量,表达式等值。

    find(int x){}

    y= find(z);

   上面的例子中,z是实参,x是形参。x变z不变。

   在值传递过程中,实参和形参位于内存中两个不同地址中,实参先自己复制一次拷贝,再把拷贝复制给形参。所以,在值传递过程中,形参的变化不会对实参有任何的影响。

2、地址传递(也称引用传递)

   实参是指针。

   在函数调用的时候,实参传递给你的是指针地址,地址一样也就意味着实参和形参是一样的,当你的形参发生改变时,实参也会发生改变。

    find(int  &x){}

    y= find(z);

    上面的例子中,z是实参,x是形参。z随x而改变。

3、const引用传递

    find(const int  &x){}

    y= find(z);

    上面的例子中,z是实参,x是形参。z不随x而改变。

    与值传递不一样的是在值传递中要进行两次拷贝,浪费内存资源是相当可耻的,const的出现有效避免了这种情况的出现,只需拷贝一次就够了。

0 0
原创粉丝点击