设计模式——简单工厂模式

简单工厂模式

  1. 通过封装、继承、多态把程序的耦合度降低。用设计模式使得程序更加的灵活,容易修改,并且易于复用。
  2. 让业务逻辑和界面逻辑分开,让它们耦合度降低,这样才容易维护和扩展。
csharp 复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

//要求输入两个数和运算符号,得到结果

namespace Calculator
{
    class Program
    {
        static void Main(string[] args)
        {
            
            Console.WriteLine("请输入一个数字");
            string strNum1 = Console.ReadLine();
            Console.WriteLine("请在输入一个数字");
            string strNum2 = Console.ReadLine();
            Console.WriteLine("请输入一个运算符");
            string strOp = Console.ReadLine();

            Operation oper = OperationFactory.CreateOperation(strOp);

            double num1 = double.Parse(strNum1);
            double num2 = double.Parse(strNum2);
            double result = oper.GetResult(num1, num2);

            Console.WriteLine($"{num1}{strOp}{num2}={result}");

        }
    }

    public class Operation
    {
        private double _numberA = 0;
        private double _numberB = 0;
        public double NumberA
        {
            get
            {
                return _numberA;
            }
            set
            {
                _numberA = value;
            }
        }
        public double NumberB
        {
            get
            {
                return _numberB;
            }
            set
            {
                _numberB = value;
            }
        }
        public virtual double GetResult(double num1,double num2)
        {
            return 0;
        }
    }

    class CalculateAdd : Operation
    {
        public override double GetResult(double num1, double num2)
        {
            return num1 + num2;
        }
    }
    class CalculateSub : Operation
    {
        public override double GetResult(double num1, double num2)
        {
            return num1 - num2;
        }
    }
    class CalculateMulti : Operation
    {
        public override double GetResult(double num1, double num2)
        {
            return num1 * num2;
        }
    }
    class CalculateDiv : Operation
    {
        public override double GetResult(double num1, double num2)
        {
            try
            {
                return num1 / num2;
            }
            catch (Exception ex)
            {
                throw ex;
            }       
        }
    }

    public class OperationFactory
    {
        static Operation oper = null;
        public static Operation CreateOperation(string op)
        {
            switch (op)
            {
                case "+":
                    oper = new CalculateAdd();
                    break;
                case "-":
                    oper = new CalculateSub();
                    break;
                case "*":
                    oper = new CalculateMulti();
                    break;
                case "/":
                    oper = new CalculateDiv();
                    break;
                default:
                    break;
            }
            return oper;
        }
    }

}
相关推荐
atunet2 分钟前
关于算法设计模式的演化与编程范式变迁的技术7
算法·设计模式
geovindu6 小时前
go:Timing Functions Pattern
开发语言·后端·设计模式·golang·计时函数模式·性能分析模式
咖啡八杯2 天前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
槑有老呆2 天前
从 Prompt Engineering 到 Harness Engineering:AI 编程的下一次跃迁
设计模式
HjhIron2 天前
从Prompt到Context:大模型应用开发的范式转移
设计模式·aigc·ai编程
咖啡八杯4 天前
GoF设计模式——中介者模式
java·后端·spring·设计模式
hez20104 天前
在 .NET 上构建超大托管数组
c#·.net·.net core·gc·clr
胡萝卜术4 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
亦暖筑序5 天前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
青禾网络7 天前
Web 前端如何接入 AI 音效生成:从零到可用的完整方案
人工智能·设计模式