策略模式及实例:四则运算

策略模式及实例:四则运算

策略模式 (Strategy Pattern)

定义一系列算法,并将每一个算法封装起来,而且使它们还可以相互替换。让算法独立于使用它的客户而独立变化。

UML

策略模式

策略模式中的角色

  • Context封装类角色
    • 启承上启下的作用
    • 屏蔽高层模块对策略、算法的直接访问
    • 封装可能的变化
  • Strategy抽象策略角色
    • 策略、算法的抽象类
  • ConcreteStrategy
    • 具体的策略角色

优点

  • 算法可自由切换
  • 避免使用多重条件判断
  • 扩展性良好

缺点

  • 类(策略类)数量增多
  • 所有的策略类都需要对外暴露
    • 与迪米特原则相违背,可用其他模式来修正(工厂、代理、享元等)

使用场景

  • 多个类只有在算法或行为上稍有不同的场景
  • 算法需要自由切换的场景
  • 需要屏蔽算法规则的场景

注意事项: 若策略类过多(>4),则需用混合模式来解决类膨胀和对外暴露的问题

实例: 四则运算

定义Strategy抽象策略类

public interface IArithmetic {
    double operation(double value1, double value2);
}

定义Context封装类

//计算器
public class Calculator {
    private final IArithmetic arithmetic;

    public Calculator(IArithmetic _arithmetic) {
        this.arithmetic = _arithmetic;
    }

    public double calc(double value1, double value2) {
        return arithmetic.operation(value1, value2);
    }
}

定义具体策略类1:加法类

public class Addition implements IArithmetic {
    @Override
    public double operation(double value1, double value2) {
        return value1 + value2;
    }
}

定义具体策略类2:减法类

public class Subtraction implements IArithmetic {
    @Override
    public double operation(double value1, double value2) {
        return value1 - value2;
    }
}

Client中调用

double value1 = 30;
double value2 = 5;
Calculator calculator;
calculator = new Calculator(new Addition());
Log.i("zhk-MainActivity", "onCreate: " + calculator.calc(value1, value2));

输出结果: 35

改为使用减法

calculator = new Calculator(new Addition());

calculator = new Calculator(new Subtraction());

输出结果: 25

现在,如果还想扩展策略类

变得非常的简单 !

新建乘法类实现IArithmetic
public class Multiplication implements IArithmetic {
    @Override
    public double operation(double value1, double value2) {
        return value1 * value2;
    }
}
Client中修改

calculator = new Calculator(new Subtraction());

calculator = new Calculator(new Multiplication());

输出结果: 150

其他

相关源码

参考 《设计模式之禅第二版》

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
1. 编一个类实现复数的运算。 复数类ComplexNumber的属性: m_dRealPart:实部,代表复数的实数部分。 m_dImaginPart:虚部,代表复数的虚数部分。 复数类ComplexNumber的方法: ComplexNumber():构造函数,将实部、虚部都置为0。 ComplexNumber(double r,double i):构造函数,创建复数对象的同时完成复数的实部、虚部的初始化,r为实部的初值,i为虚部的初值。 getRealPart():获得复数对象的实部。 getImaginPart():获得复数对象的虚部。 setRealPart(double d):把当前复数对象的实部设置为给定的形式参数的数字。 setImaginaryPart(double d):把当前复数对象的虚部设置为给定的形式参数的数字。 complexAdd(ComplexNumber c):当前复数对象与形式参数复数对象相加,所得的结果也是复数值,返回给此方法的调用者。 complexAdd(double c):当前复数对象与形式参数实数对象相加,所得的结果仍是复数值,返回给此方法的调用者。 complexMinus(ComplexNumber c) :当前复数对象与形式参数复数对象相减,所得的结果也是复数值,返回给此方法的调用者。 complexMinus(double c) :当前复数对象与形式参数实数对象相减,所得的结果仍是复数值,返回给此方法的调用者。 complexMulti(ComplexNumber c):当前复数对象与形式参数复数对象相乘,所得的结果也是复数值,返回给此方法的调用者。 complexMulti(double c):当前复数对象与形式参数实数对象相乘,所得的结果仍是复数值,返回给此方法的调用者。 toString():把当前复数对象的实部、虚部组合成a+bi的字符串形式,其中和分别为实部和虚部的数据。 2. 编Java Application程序使用上题定义的类,检查类定义是否正确。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

氦客

你的鼓励是我创作最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值