zoukankan      html  css  js  c++  java
  • C语言 指针在函数传参中的使用

    int add(int a, int b)   //函数传参的时候使用了int整型数据,本身是数值类型。实际调用该函数时,实参将自己拷贝一份,并将拷贝传递给形参进行运算。实参自己实际是不参与运算的。所以在该函数中,实参本身是没有得到改变的。

    int main()

    {

      int x = 3, y = 5;

           swap(x, y);

      printf("x = %d ,y = %d ",x, y);  //交换失败

           swap_pointer(&x, &y);

      printf("x = %d ,y = %d ",x, y);  //交换成功

    }

    int swap(int a, int b)     //C语言中,函数调用时,实参传递给形参实际是传值调用。也就是说,实参x和y将自己的值拷贝一份传给形参 a 和 b;因此在函数swap中实际得到交换的是 a 和 b,而不是实参 x 和 y,因此函数执行完后,x和y的值依然没有改变。

    {

      int temp;

      temp = a;     //a是swap里边的形参,实际调用时得到的是实参x的一份拷贝,只是和x的值相等而已,其他并无任何关联,因此在这里不能访问到实参x

           a = b;

      b = temp;

      return 0;

    }

    int swap_pointer(int *p1, int *p2)   //C语言函数调用时,一直都是传值调用。也就是说实际传递的一直都是实参的拷贝,但是在本函数中的形参和实参都不是x和y,而是x和y的地址值。这样的话,就让我们在调用函数里通过间接访问*p的方式,访问到了函数外部的实参。                                                      //(如果不使用指针,再调用函数内部只能访问到形参,无法访问到函数外部的实参)

    {

      int temp;

      temp = *p1;     //实际调用时,p1得到的实参是x的地址&x,所以*p1代表的就是x

           *p2 = *p1;

           *p1 = temp;

           return 0;

    }

  • 相关阅读:
    cuda9.0 中不存在libnppi.so
    深度学习训练踩坑记
    采用代理之后,pip 运行报错socks
    摄像机模型
    段错误:使用opencv打开视频流
    ffmpeg+cuda+opencv
    pip install xxx -i https://pypi.tuna.tsinghua.edu.cn/simple
    【TCP/IP详解】BOOTP:引导程序协议
    【TCP/IP详解】TFTP:简单文件传送协议
    【TCP/IP详解】IGMP Internet组管理协议
  • 原文地址:https://www.cnblogs.com/jiangtongxue/p/11079651.html
Copyright © 2011-2022 走看看