• C语言形参和实参的区别(非常详细)


    如果把函数比喻成一台机器,那么参数就是原材料,返回值就是最终产品;从一定程度上讲,函数的作用就是根据不同的参数产生不同的返回值。

    这一节我们先来讲解C语言函数的参数,下一节再讲解C语言函数的返回值。

    C语言函数的参数会出现在两个地方,分别是函数定义处和函数调用处,这两个地方的参数是有区别的。

    形参(形式参数)

    在函数定义中出现的参数可以看做是一个占位符,它没有数据,只能等到函数被调用时接收传递进来的数据,所以称为形式参数,简称形参

      这里按自己的理解为什么说形参看作一个占位符,后文还说到在调用之前并没有给他分配内存,看上去这两段是有些矛盾的,其实机器在时间上的运行顺序这么说没毛病;

      本人理解是在程序编译过程中,程序计数器不断加以程序顺序执行,执行到调用函数位置时,会将之前的数据压栈就像中断一样,调用前要传递实参值对应的内存位置并没有开辟,所以可以说形参再调用前不占内存;

      但是这里没有开辟不是说实参会传到随机的位置,这是不会发生的,程序在编译好之后,每执行一条指令,数据都会有个确切的内存位置对应(这是在编译器编译的时候就已经确定好的),所以这么说来,形参确实是一个占位符(占有一个内存地址的位置);

      只是调用前别的参数也可以占用这个位置,但编译器编译的时候肯定不会让一个全局变量的内存地址和分配给形参的内存地址是同一个地址,原因大家应该通过上面的解释也明白编译器在编译时不会让两个没有关联的变量,同时服务于一个地址这样会造成数据的混乱。

      就像两个服务员负责同一桌客人时,当客人需要一瓶饮料时,两个服务员分别在不同时刻听到,可能就会造成给客人拿两瓶情况。

    实参(实际参数)

    函数被调用时给出的参数包含了实实在在的数据,会被函数内部的代码使用,所以称为实际参数,简称实参

    形参和实参的功能是传递数据,发生函数调用时,实参的值会传递给形参。

    形参和实参的区别和联系

    1) 形参变量只有在函数被调用时才会分配内存,调用结束后,立刻释放内存,所以形参变量只有在函数内部有效,不能在函数外部使用。

    2) 实参可以是常量、变量、表达式、函数等,无论实参是何种类型的数据,在进行函数调用时,它们都必须有确定的值,以便把这些值传送给形参,所以应该提前用赋值、输入等办法使实参获得确定值。

    3) 实参和形参在数量上、类型上、顺序上必须严格一致,否则会发生“类型不匹配”的错误。当然,如果能够进行自动类型转换,或者进行了强制类型转换,那么实参类型也可以不同于形参类型。

    4) 函数调用中发生的数据传递是单向的,只能把实参的值传递给形参,而不能把形参的值反向地传递给实参;换句话说,一旦完成数据的传递,实参和形参就再也没有瓜葛了,所以,在函数调用过程中,形参的值发生改变并不会影响实参。

    请看下面的例子:

     1 #include <stdio.h>
     2 //计算从m加到n的值
     3 int sum(int m, int n) 
     4 {
     5     int i;
     6     for (i = m+1; i <= n; ++i) 
     7     {
     8         m += i;
     9     }
    10     return m;
    11 }
    12 int main()
    13 {
    14     int a, b, total;
    15     printf("Input two numbers: ");
    16     scanf("%d %d", &a, &b);
    17     total = sum(a, b);
    18     printf("a=%d, b=%d
    ", a, b);
    19     printf("total=%d
    ", total);
    20     return 0;
    21 }

    运行结果:
    Input two numbers: 1 100↙
    a=1, b=100
    total=5050

    在这段代码中,函数定义处的 m、n 是形参,函数调用处的 a、b 是实参。通过 scanf() 可以读取用户输入的数据,并赋值给 a、b,在调用 sum() 函数时,这份数据会传递给形参 m、n。

    从运行情况看,输入 a 值为 1,即实参 a 的值为 1,把这个值传递给函数 sum() 后,形参 m 的初始值也为 1,在函数执行过程中,形参 m 的值变为 5050。函数运行结束后,输出实参 a 的值仍为 1,可见实参的值不会随形参的变化而变化。

    以上调用 sum() 时是将变量作为函数实参,除此以外,你也可以将常量、表达式、函数返回值作为实参,如下所示:

    1. total = sum(10, 98); //将常量作为实参
    2. total = sum(a+10, b-3); //将表达式作为实参
    3. total = sum( pow(2,2), abs(-100) ); //将函数返回值作为实参


    5) 形参和实参虽然可以同名,但它们之间是相互独立的,互不影响,因为实参在函数外部有效,而形参在函数内部有效。

    更改上面的代码,让实参和形参同名:

     1 #include <stdio.h>
     2 //计算从m加到n的值
     3 int sum(int m, int n) 
     4 {
     5     int i;
     6     for (i = m + 1; i <= n; ++i)    
     7     {
     8         m += i;
     9     }
    10     return m;
    11 }
    12 int main()
    13  {
    14     int m, n, total;
    15     printf("Input two numbers: ");
    16     scanf("%d %d", &m, &n);
    17     total = sum(m, n);
    18     printf("m=%d, n=%d
    ", m, n);
    19     printf("total=%d
    ", total);
    20     return 0;
    21 }       

    运行结果:
    Input two numbers: 1 100
    m=1, n=100
    total=5050

    调用 sum() 函数后,函数内部的形参 m 的值已经发生了变化,而函数外部的实参 m 的值依然保持不变,可见它们是相互独立的两个变量,除了传递参数的一瞬间,其它时候是没有瓜葛的。

  • 相关阅读:
    POJ2528——Mayor's posters (线段树区间更新查询+离散化)
    C++STL——unique函数总结
    HDU 5618 Jam's problem again(CDQ分治+树状数组(三维模板题))
    c++解决爆栈,手动加栈!
    POJ1741——Tree (树分治之点分治)
    树分治之点分治模板总结
    CodeForces
    字典树
    卡特兰数高精度算法
    基数排序
  • 原文地址:https://www.cnblogs.com/zhj868/p/14180848.html
Copyright © 2020-2023  润新知