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

详谈:解释器模式(二)

接上文。

看到这个需求,我们很容易想到一种写法:将输入的字符串分割成单个字符,把数字字符通过switch-case转换为数字,再通过计算符判断是加法还是减法,对应做加、减计算,最后返回结果即可。

计划的确可行,但这实在太面向过程了,众所周知面向过程编程会有耦合度高,不易扩展等缺点。接下来我们尝试按照面向对象的写法来实现这个功能。

按照面向对象的编程思想,我们应该为公式中不同种类的元素建立一个对应的对象。那么我们先分析一下公式中的成员:

  • 数字:零到九对应0 ~ 9
  • 计算符:加、减对应+、-

公式中仅有这两种元素,其中对于数字的处理比较简单,只需要通过switch-case将中文名翻译成阿拉伯数字即可。

http://www.gsyq.cn/news/99323.html

相关文章:

  • 新能源逆变器那些事儿:阻抗建模、扫频验证与稳定性分析
  • Dockerfile 详解
  • 【大模型预训练】17-分布式并行策略:Tensor并行、Pipeline并行的应用场景
  • 货运 app 运输管理系统框架搭建
  • 三相并联型有源电力滤波器APF仿真探索
  • 匠魂的熔炼注册
  • Socket编程与编码转换实战指南
  • 【博士生必看】博士论文被退稿?可能是AI惹的祸!Paperzz智能降重+降AIGC,守护你的学术尊严!
  • PRML为何是机器学习的经典书籍中的经典?
  • 晶体塑性有限元多晶Voronoi模型生成:Neper软件在Linux系统下的神奇之旅
  • 核技巧
  • Redis缓存三大问题详解:击穿、穿透与雪崩的解决方案
  • 在C# 中搭建基于VisionPro的多相机多线程采集与Socket通讯的视觉系统
  • obsidian(md笔记管理)使用实践
  • RFID资产管理:数据安全措施全解析,企业必看指南
  • PPO是属于什么类型的RL算法,on policy还是off policy
  • 56(12.10))
  • 【Python大数据项目推荐】Spark+Django共享单车数据分析可视化系统实现 毕业设计 选题推荐 毕设选题 数据分析 机器学习
  • 某安全so库深度解析
  • 压缩文件夹下下所有文件成压缩包tar.gz--随笔016
  • Emacs折腾日记(三十三)——org实现gtd任务管理系统
  • 57(12.11)
  • 【Python大数据分析选题】基于Hadoop+Spark的股市行情可视化平台 毕业设计 选题推荐 毕设选题 数据分析 机器学习
  • 【开题答辩全过程】以 基于协同过滤算法的经济型酒店推荐系统为例,包含答辩的问题和答案
  • 58(12.12)
  • 华为开源自研AI框架昇思MindSpore实战:手把手带你用GAN生成手写数字
  • 影刀RPA竞品分析黑科技!AI一键生成TikTok竞品报告,效率提升1000% [特殊字符]
  • 堆箱子问题:从暴力递归到动态规划的优化之路
  • C语言图论:最短路径算法
  • 教程7:行为树的连调-–-behaviac