自己动手写计算器v1.1
这个改动主要是使用工厂模式替代了简单工厂模式,这样做的好处是如果以后我们要扩充其他运算时,就不用总是去修改工厂类,
这是可以采取工厂模式,主要是将原来简单工厂类的逻辑判断分离出来,将它作为一个借口,与此同时,我们新建运算符工厂类,继承这些借口,
重写里面的getResult()方法,获取对应的运算对象。
这样做的好处在于,满足了“少修改,多扩充”的原则。缺点是:要将逻辑代码写在客户端,这样很难维护,以后会做改进。
代码如下:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace 计算器 { //简述:用工厂模式取代了简单工厂模式,对比与简单工厂模式,工厂模式,将简单工厂类中的逻辑判断利用接口分离了开来。 interface Result { OperatorV1_1 getOperatorV1_1(); } class plusOperatorV1_1Factory:Result { public OperatorV1_1 getOperatorV1_1() { return new plusOperatorV1_1(); } } class jianOperatorV1_1Factory:Result { public OperatorV1_1 getOperatorV1_1() { return new jianOperatorV1_1(); } } class chenOperatorV1_1Factory:Result { public OperatorV1_1 getOperatorV1_1() { return new chenOperatorV1_1(); } } class chuOperatorV1_1Factory:Result { public OperatorV1_1 getOperatorV1_1() { return new chenOperatorV1_1(); } } class OperatorV1_1 { public virtual string GetResult(double num1, double num2) { return "error"; } } class plusOperatorV1_1 : OperatorV1_1 { public override string GetResult(double num1, double num2) { return (num1 + num2).ToString(); } } class jianOperatorV1_1 : OperatorV1_1 { public override string GetResult(double num1, double num2) { return (num1 - num2).ToString(); } } class chenOperatorV1_1 : OperatorV1_1 { public override string GetResult(double num1, double num2) { return (num1 * num2).ToString(); } } class chuOperatorV1_1 : OperatorV1_1 { public override string GetResult(double num1, double num2) { if (num2 == 0) { return "除数不能为0"; } else { return (num1 / num2).ToString(); } } } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话