C语言进阶课程学习记录-函数参数的秘密

C语言进阶课程学习记录-函数参数的秘密


本文学习自狄泰软件学院 唐佐林老师的 C语言进阶课程,图片全部来源于课程PPT,仅用于个人学习记录

在这里插入图片描述
在这里插入图片描述

实验

#include <stdio.h>

int func(int i, int j)
{
    printf("%d, %d\n", i, j);

    return 0;
}

int main()
{
    int k = 1;

    func(k++, k++);//warning: operation on 'k' may be undefined [-Wsequence-point]|

    printf("%d\n", k);

    return 0;
}


    /*
2, 1
3

*/

在这里插入图片描述
在这里插入图片描述

实验

#include <stdio.h>

int main()
{
    int k = 2;
    int a = 1;

    k = k++ + k++;

    printf("k = %d\n", k);

    if( a-- && a )
    {
        printf("a = %d\n", a);
    }

    return 0;
}


    /*
k = 6

*/

小结

函数的参数在栈上分配空间
函数的实参并没有固定的计算次序
顺序点是C语言中变量修改的最晚时机

调用约定

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

实验-求平均数

#include <stdio.h>

float average(int array[], int size)
{
    int i = 0;
    float avr = 0;

    for(i=0; i<size; i++)
    {
        avr += array[i];
    }

    return avr / size;
}

int main()
{
    int array[] = {1, 2, 3, 4, 5};

    printf("%f\n", average(array, 5));

    return 0;
}


    /*
3.000000

*/

在这里插入图片描述

实验-可变参数的函数

#include <stdio.h>
#include <stdarg.h>

float average(int n, ...)
{
    va_list args;
    int i = 0;
    float sum = 0;

    va_start(args, n);

    for(i=0; i<n; i++)
    {
        sum += va_arg(args, int);
    }

    va_end(args);

    return sum / n;
}

int main()
{
    printf("%f\n", average(5, 1, 2, 3, 4, 5));
    printf("%f\n", average(4, 1, 2, 3, 4));

    return 0;
}


    /*
3.000000
2.500000

*/

在这里插入图片描述

小结

调用约定指定了函数参数的入栈顺序以及栈的清理方式
可变参数是C语言提供的一种函数设计技巧
可变参数的函数提供了一种更方便的函数调用方式
可变参数必须顺序的访问,无法直接访问中间的参数值

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-22 07:10:03       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-22 07:10:03       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-22 07:10:03       87 阅读
  4. Python语言-面向对象

    2024-04-22 07:10:03       96 阅读

热门阅读

  1. 基于SpringCloudAlibaba+Sentinel的分布式限流设计

    2024-04-22 07:10:03       36 阅读
  2. 搜索+剪枝,LeetCode 216. 组合总和 III

    2024-04-22 07:10:03       33 阅读
  3. 【iOS安全】iOS ARM汇编

    2024-04-22 07:10:03       37 阅读
  4. 组合总和(Lc39)——排序+剪枝+回溯

    2024-04-22 07:10:03       31 阅读
  5. 【无标题】axios的ts封装,记录一下(Vue3项目)

    2024-04-22 07:10:03       26 阅读
  6. STM32相关手册

    2024-04-22 07:10:03       30 阅读
  7. 搜索引擎中的倒排索引是什么

    2024-04-22 07:10:03       37 阅读
  8. 【数据结构】冒泡排序

    2024-04-22 07:10:03       35 阅读
  9. docker安装mysql,允许远程连接

    2024-04-22 07:10:03       35 阅读