• 第7章 C语言的函数指针数组 (四)


    文档视频讲解链接地址

    1. 腾讯课堂链接 : 68_函数_函数指针数组
    2. 腾讯课堂链接 : 69_函数_函数小节复习

    7.4 函数指针数组

    1. 函数指针数组

      • 那要把函数的地址存到一个数组中,那这个数组就叫函数指针数组,
      • 函数指针数组是一个保存若干个函数名的数组。
      • 一般形式如下:
      <数据类型>    ( * <函数指针数组名称> [<大小>] ) ( <参数说明列表> )
      • 1
      • 例如:
      int (*fun[10])(int); 
      // 因为[] 的优先级比*高 , func先结合[] , 因此func是一个数组 
      // 此时的* 就是起到了修饰的作用  , 这个数组就是 指针类型的数组
      // 什么类型的指针呢?  
      // 是函数类型的指针 , 返回值int , 形参是int 的函数 
      // 最终是:函数类型指针数组, 简称函数指针数组 
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
    2. 实例94

      • 使用函数指针数组来批量调用函数
      • 源文件
      01-cbase\94-function.c
      
      • 1
      • 源代码
      #include  
      #include  
      
      
      
      // 函数使用的三个步骤 
      
      // 2. 函数的声明   
      // 函数定义在main之前, 可以省略声明部分 
      
      // 1. 函数定义
      // 函数定义的三要素  函数名 , 形参 , 返回值 
      // 函数名 : add 
      // 形参   : int x , int y  
      // 返回值 : int 
      int  add(int x, int y)
      {
          return x+y ; 
      }
      int sub(int x, int y)
      {
          return x-y; 
          // ...
      }
      int mul(int x, int y)
      {
          return x*y; 
          // ...
      }
      
      int div(int x, int y)
      {
          return x/y;
          // ...
      }
      
      // x^y 计算次方 使用pow函数来计算 
      int mypow(int x, int y) 
      {
          return (int)pow(x,y);
          // ...
      }
      
      
      int main(int argc, char const *argv[])
      {
          // 3. 函数的调用 
          // 先定义个函数指针数组 
          int  (*pfunc[5])(int x, int y) ; // 定义一个数组, 里面有5个元素, 每一个元素都是一个函数指针变量 
          pfunc[0] = add; 
          pfunc[1] = sub; 
          pfunc[2] = mul; 
          pfunc[3] = div; 
          pfunc[4] = mypow; 
      
          for(int i=0;i<5;i++)
          {
              printf("pfunc[%d]=%p\n",i,pfunc[i]);
          }
      
          int  a=10,b=5,ret=0; 
          for(int i=0;i<5;i++) // 可以使用for循环来批量调用函数 
          {
              //i=0 ,  pfunc[0] = add, 相等于 add(a,b);
              //i=1 ,  pfunc[1] = sub, 相等于 sub(a,b);
              //i=2 ,  pfunc[2] = mul, 相等于 mul(a,b);
              //i=3 ,  pfunc[3] = div, 相等于 div(a,b);
              //i=4 ,  pfunc[4] = mypow, 相等于 mypow(a,b);
              ret = pfunc[i](a,b);  
      
              printf("ret=%d\n",ret);
          }
      
      
         
          return 0;
      }
      
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14
      • 15
      • 16
      • 17
      • 18
      • 19
      • 20
      • 21
      • 22
      • 23
      • 24
      • 25
      • 26
      • 27
      • 28
      • 29
      • 30
      • 31
      • 32
      • 33
      • 34
      • 35
      • 36
      • 37
      • 38
      • 39
      • 40
      • 41
      • 42
      • 43
      • 44
      • 45
      • 46
      • 47
      • 48
      • 49
      • 50
      • 51
      • 52
      • 53
      • 54
      • 55
      • 56
      • 57
      • 58
      • 59
      • 60
      • 61
      • 62
      • 63
      • 64
      • 65
      • 66
      • 67
      • 68
      • 69
      • 70
      • 71
      • 72
      • 73
      • 74
      • 75
      • 76
      • 77
      • 78
      • ​ 运行结果
      pfunc[0]=0000000000401550
      pfunc[1]=0000000000401564
      pfunc[2]=0000000000401576
      pfunc[3]=0000000000401589
      pfunc[4]=000000000040159C
      ret=15
      ret=5
      ret=50
      ret=2
      ret=100000
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
  • 相关阅读:
    IMMA~~
    ROS(0)命令及学习资源汇总
    【机器学习基础】无监督学习(5)——生成模型
    虹科分享 | 软件供应链攻击如何工作?如何评估软件供应链安全?
    ES6 类的扩展
    在ios系统上实现更改IP地址
    KendoReact R2 2022
    (十一)PostgreSQL的wal日志(2)-默认wal日志大小
    VTK Filter-Modeling模块讲解
    为什么现在很多人特别排斥用微信打电话
  • 原文地址:https://blog.csdn.net/shengli001842/article/details/126731372