从头开始——简单工厂设计模式

本文介绍了一种基于设计模式实现的计算器程序,通过将显示、运算逻辑分离,并利用抽象工厂模式来动态生成不同的运算器,实现了良好的扩展性和维护性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

计算器尽可能的分离功能。
首先显示与运算分开。
然后运算与实际运算分开。
运算的共性是:数值 运算符 结果
能区别运算方式的就是运算符,也就是说运算符决定了数值和结果
可以通过运算符来决定生成相应的运算器
父类:数值、结果
子类:继承过来然后单独写方法
最后再用工厂根据相应的运算符生成运算器并return
abstract class Operation {
 private double numberA;
 private double numberB;

 public double getNumberA() {
  return numberA;
 }

 public void setNumberA(double numberA) {
  this.numberA = numberA;
 }

 public double getNumberB() {
  return numberB;
 }

 public void setNumberB(double numberB) {
  this.numberB = numberB;
 }

 public abstract double getResult();
}

class OperationAdd extends Operation {
 @Override
 public double getResult() {
  return getNumberA() + getNumberB();
 }
}

class OperationSub extends Operation {
 @Override
 public double getResult() {
  return getNumberA() - getNumberB();
 }
}

class OperationMul extends Operation {
 @Override
 public double getResult() {
  return getNumberA() * getNumberB();
 }
}

class OperationDiv extends Operation {
 @Override
 public double getResult() {
  if (getNumberB() == 0)
   throw new RuntimeException("除数不能为0");
  return getNumberA() / getNumberB();
 }
}
class OperationFactory {
 public static Operation createOperation(String operate) {
  Operation oper = null;
  switch (operate) {
  case "+":
   oper = new OperationAdd();
   break;
  case "-":
   oper = new OperationSub();
   break;
  case "*":
   oper = new OperationMul();
   break;
  case "/":
   oper = new OperationDiv();
   break;
  }
  return oper;
 }
}
public class Demo {
 public static void main(String[] args) {
  Operation oper = OperationFactory.createOperation("+");
  oper.setNumberA(1);
  oper.setNumberB(2);
  System.out.println(oper.getResult());
 }
}

多个工厂方法模式:
需要什么调用相应方法

静态工厂模式:
不用创建工厂对象,直接调用工厂中的方法

缺陷:以上几种模式,当增加了接口的子类时,需要修改工厂类,违背了闭包原则
所以使用抽象工厂模式
给所有的工厂类定义接口
interface produce
{
    public Send producer();
}

class ProduceFactory implements produce{
    public Send producer(){
        
    }
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值