当前位置: 首页 > article >正文

C程序设计——再说说函数参数的值传递

上一篇的最后,我强调了C语言里,所有函数参数的传递,都是值传递,即形参值改变,不影响实参的值。

指针作为函数参数

我们知道,指针也是C语言的一个类型,所以指针,也可以作为函数参数,请看源代码:

int TestParam(int* ipA, int* ipB)
{
    printf("aa.  ipA == %x, ipB == %x\r\n", ipA, ipB);

    ipA = 0;
    ipB = 0;
    printf("ab.  ipA == %x, ipB == %x\r\n", ipA, ipB);
    return 0;
}

int main(void)
{
    int y, z ;
    int *ipa, *ipb;

    y = 0x10;
    z = 0x15;

    ipa = &y;
    ipb = &z;

    printf("a.   ipa == %x, ipb == %x\r\n", ipa, ipb);
    printf("b.   y == %x,   z == %x\r\n", y, z);

    TestParam(ipa, ipb);

    printf("c.   ipa == %x, ipb == %x\r\n", ipa, ipb);
    printf("e.   y == %x,   z == %x\r\n", y, z);
}

我们可以看到,上面的源码中,有六行打印,分别是 a,b,c,e, aa, ab ,从源码上看,main函数调用 TestParam 时,ipa 和 ipb 时实参,因此,aa行打印的ipA 和ipB的值,应该跟第a行是一样的。到打印 ab行之前,因为 ipA 和ipB 都被赋值为0了,因此,ab行打印的值应该是两个0。打印第c行时,因为形参改变,不影响实参,因此第c 行打印的值,应该跟a行是一样的。至于变量y 和 z的值,它俩在这个代码里,就是打酱油的,所以赋值之后就没有变化,一直是0x10 和0x15。所以代码执行结果如下:

如果我们把源码做一个小小的修改, 注意看注释:

int TestParam(int* ipA, int* ipB)
{
    printf("aa.  ipA == %x, ipB == %x\r\n", ipA, ipB);
/*******************************
    注意下面这两行,跟刚才不一样
*******************************/
    *ipA = 0; //注意这里跟刚才不一样
    *ipB = 0; //注意这里跟刚才不一样
    printf("ab.  ipA == %x, ipB == %x\r\n", ipA, ipB);
    return 0;
}

int main(void)
{
    int y, z ;
    int *ipa, *ipb;

    y = 0x10;
    z = 0x15;

    ipa = &y;
    ipb = &z;

    printf("a.   ipa == %x, ipb == %x\r\n", ipa, ipb);
    printf("b.   y == %x,   z == %x\r\n", y, z);

    TestParam(ipa, ipb);

    printf("c.   ipa == %x, ipb == %x\r\n", ipa, ipb);
    printf("e.   y == %x,   z == %x\r\n", y, z);
}

TestParam函数里,我没有改变形参的值,而是改变了形参指向的变量的值,我们知道ipA 和ipB的值分别是 ipa 和 ipb的值,而 ipa 和 ipb 又分别指向 x 和 y,因此下面这两行源码,改变的应该是x 和 y的值:

/*******************************
    注意下面这两行,跟刚才不一样
*******************************/
    *ipA = 0; //注意这里跟刚才不一样
    *ipB = 0; //注意这里跟刚才不一样

因此,主函数中,b行和 e行打印的值应该不一样,执行结果如下:

再次强调:C语言里,所有函数参数的传递,都是值传递,即形参值改变,不影响实参的值。上述代码里,TestParam的参数,是指针,而不是指针指向的值。因此TestParam函数里,只是通过形参指针改变了实参指针指向的值,并没有改变实参本身,因此再强调一遍:形参值改变,不影响实参的值。

形参和实参是两个不同的变量

请看源码,虽然形参变量名和实参变量名是一样的,但是他们是不同的变量,即形参改变不影响实参的值。

/*********************************************
    注意函数的形参变量名
*********************************************/
int TestParam(int x, int y)
{
    printf("aa.  x == %x, y == %x\r\n", x, y);

    x = 0;
    y = 0;
    printf("ab.  x == %x, y == %x\r\n", x, y);
    return 0;
}

int main(void)
{
    int x, y ;

    x = 0x10;
    y = 0x15;

    printf("b.   x == %x,   y == %x\r\n", x, y);

/*********************************************
    注意看实参的变量名
*********************************************/
    TestParam(x, y);

    printf("e.   x == %x,   y == %x\r\n", x, y);
}

所以上述代码,执行结果如下:

虽然形参变量名和实参变量名一样,但是他们是不同的变量,再强调一遍:形参值改变,不影响实参的值。


http://www.kler.cn/a/298808.html

相关文章:

  • YOLO原理讲解
  • RK3506开发板:智能硬件领域的新选择,带来卓越性能与低功耗
  • 强大且灵活的终端工具Tabby的强大功能与详细配置指南
  • 服务器压力测试怎么做
  • Linux挖矿程序排查
  • springboot项目对数据库密码加解密
  • 支持iPhone 16新品预售,饿了么同步上线专人配送等特色服务
  • 李诞-2021.8脱口秀工作手册-11-pitch your idea把一个想法扎进别人脑子里;专业,做足准备,给选择option!
  • 5.2 排列与代数余子式
  • 大模型实战一、Ollama+RagFlow 部署本地知识库
  • 三.海量数据实时分析-FlinkCDC实现Mysql数据同步到Doris
  • 数学建模笔记——熵权法(客观赋权法)
  • 【开源免费】基于SpringBoot+Vue.JS图书个性化推荐系统(JAVA毕业设计)
  • STM32的CRC校验(基于HAL库)
  • k8s 存储(PV、PVC、SC、本地存储、NFS)
  • 观趋势 谋发展 2024 SSHT上海智能家居展有哪些创新呈现?
  • 元学习之模型诊断元学习(model-agnosticmeta-learning,MAML)
  • SLT—List详解
  • 【iOS】暑期学习总结
  • python求两条曲线的边界线
  • 什么是过压保护?常见的过压保护元器件有哪些?
  • 零基础国产GD32单片机编程入门(十三)单片机IAP(在应用编程)详解及实战源码
  • 基于MicroPython的ESP8266控制舵机的设计方案
  • 继承QWidget样式表无效的
  • Learn ComputeShader 10 HUD Overlay
  • Android13 Hotseat客制化--去掉hotseat(热座)