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

#C语言——学习攻略:深挖指针路线(四续)——函数指针数组--转移表

🌟菜鸟主页:@晨非辰的主页

👀学习专栏:《C语言学习》

💪学习阶段:C语言方向初学者

名言欣赏:"暴力解法是上帝给的,优化解法是魔鬼教的。"


目录

1. 转移表


1. 转移表

--在此之前,先用函数实现一下计算器的功能开开胃:

  • 一般的实现方式:
//构建运算功能函数
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;
}//定义菜单函数
void menu()
{printf("****************************\n");printf("******1.Add     2.Sub******\n");printf("******3.Mul     3.Div******\n");printf("*********  0.exit  *********\n");printf("****************************\n");
}int main()
{int x = 0;int y = 0;int input = 0;int ret = 0;do{menu();printf("请选择:");scanf("%d", &input);switch (input){case 1:printf("执行加法运算,请输入操作数:");scanf("%d %d", &x, &y);ret = Add(x, y);printf("%d\n", ret);break;case 2:printf("执行减法运算,请输入操作数:");scanf("%d %d", &x, &y);ret = Sub(x, y);printf("%d\n", ret);break;case 3:printf("执行乘法运算,请输入操作数:");scanf("%d %d", &x, &y);ret = Mul(x, y);printf("%d\n", ret);break;case 4:printf("执行除法运算,请输入操作数:");scanf("%d %d", &x, &y);ret = Div(x, y);printf("%d\n", ret);break;case 0:printf("已退出计算器\n");break;default:printf("选择错误\n");break;}} while (input);return 0;
}

--上面这一大串代码,虽然目前能够实现几个简单的运算功能,但因为其中的大部分代码实现的作用一样,整体来看显得代码过于重复;而且以后若要添加新的运算功能,非常不利于进行修改,所以在这里使用所学的函数指针数组进行代码的优化:

  • 优化后:添加转移表

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;
}void menu()
{printf("****************************\n");printf("******1.Add      2.Sub******\n");printf("******3.Mul      3.Div******\n");printf("*********  0.exit  *********\n");printf("****************************\n");
}int main()
{int x = 0;int y = 0;int input = 0;int ret = 0;//转移表int (*pf[5])(int x, int y) = { NULL,Add,Sub,Mul,Div };//加上空指针,是因为数组通过下标进行运作,为了确保下标所指内容与菜单的数字对应do{menu();printf("请选择:");scanf("%d", &input);//保证input在可许范围内if (input >= 1 && input <= 4){printf("请输入操作数:");scanf("%d %d", &x, &y);ret = pf[input](x, y);printf("%d\n", ret);}else if (input == 0){printf("已退出计算机程序\n");}else{printf("选择错误\n");}} while (input);return 0;
}

--对于转移表:是一种高效分支跳转技术,它们的主要作用是优化多分支条件判断(如switch - case 或if - else链),提升代码的可读性、灵活性和执行效率。 


相关内容回顾:

#C语言——学习攻略:深挖指针路线(四)--字符指针变量,数组指针变量,二维数组传参的本质,函数指针变量,函数指针数组


结语:本篇文章旨在分享像一片博客最后所提到的函数指针数组的用途--转移表的使用,通过对一个简单的函数实现功能的优化体现了函数指针数组的用途;指针的内容需要反复研读 ,如果这篇文章对你的学习有帮助的话,欢迎一起讨论学习,你这么帅、这么美给个三连吧

http://www.dtcms.com/a/305753.html

相关文章:

  • 【支持Ubuntu22】Ambari3.0.0+Bigtop3.2.0——Step4—时间同步(Chrony)
  • 从0开始学习R语言--Day62--RE插补
  • STL学习(?、常用的算数算法和集合算法)
  • 跳跃表可视化深度解析:动态演示数据结构核心原理
  • 数据结构第3问:什么是线性表?
  • 数据结构-Set集合(一)Set集合介绍、优缺点
  • 基于 Rust 和土木工程、设备故障诊断、混凝土养护、GPS追踪、供应链物流跟踪系统、地下水监测等领域的实例
  • CouchDB 从入门到精通:构建高效的分布式文档数据库
  • cpp实现音频重采样8k->16k及16k->8k
  • 2025年华为HCIA-AI认证是否值得考?还是直接冲击HCIP?
  • c++函数返回值完整总结
  • GaussDB 数据库架构师(十二) 数据库对象修改审计设置
  • (RedmiBook)上禁用触摸板或自带键盘
  • 【LangGraph技术深度解析】构建下一代AI工作流的革命性框架
  • 数据赋能(358)——数据分析——可解释性原则
  • ZKMall商城开源本地部署指南
  • 【Rust多进程】征服CPU的艺术:Rust多进程实战指南
  • 2419. 按位与最大的最长子数组
  • web服务器nginx
  • 新零售“实—虚—合”逻辑下的技术赋能与模式革新:基于开源AI大模型、AI智能名片与S2B2C商城小程序源码的研究
  • 标准七层网络协议和TCP/IP四层协议的区别
  • uni-app webview 的message无法触发的解决方案
  • 在 Elasticsearch 8.19 和 9.1 中引入更强大、更具弹性和可观测性的 ES|QL
  • jenkins连接docker失败【还是没解决】
  • 关于MyBatis 的懒加载(Lazy Loading)机制
  • Hutool 的 WordTree(敏感词检测)
  • 阿里云AI代码助手通义灵码开发指导
  • Javaweb————什么是OPTIONS预检请求
  • 2025年6月数据挖掘顶刊TKDE研究热点有哪些?
  • 磁悬浮技术原理