策略模式:策略模式是一种定义一系列算法的方法,算法完成的工作都是相同的工作,但是实现不同,它可以以相同的方式调用所有的算法,减少了各种算法类与使用算法类之间的耦合。
Java实现一个策略模式:
需求:商场收银系统,收银方式为正常收费,打八折,满300返100,这三种收费方式。
1:创建一个超类。即收费的抽象方法。
1
2
3
|
public abstract class CashSuper { public abstract double acceptCash( double money); } |
2:创建实现此超类的类。
1
2
3
4
5
6
7
8
|
public class CashNormal extends CashSuper { @Override public double acceptCash( double money) { return money; } } |
3:根据商场收费方式的不同,创建三种收费方式的具体实现算法类
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
/**打折子类 * 获取打折折扣,使用应付金额乘以折扣 * @author 我不是张英俊 * */ public class CashRebate extends CashSuper { private double moneyRebate= 1 ; public CashRebate(String moneyRebate){ this .moneyRebate=Double.parseDouble(moneyRebate); } @Override public double acceptCash( double money) { return money*moneyRebate; } } |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
/**返利收费子类,例如,满三百减一百 * @author 我不是张英俊 * */ public class CashReturn extends CashSuper { /** * 返利收费,初始化时必须要输入返利条件和返利值,比如慢300时返100, * 则moneyCondition为300,moneyRetrun 为100 */ private double moneyCondition= 0 ; private double moneyReturn= 0 ; public CashReturn(String moneyCondition,String moneyReturn){ this .moneyCondition=Double.parseDouble(moneyCondition); this .moneyReturn=Double.parseDouble(moneyReturn); } @Override public double acceptCash( double money) { double result=money; if (money>=moneyCondition){ result=money-Math.floor(money/moneyCondition)*moneyReturn; } return result; } } |
1
2
3
4
5
6
7
8
9
10
11
12
13
|
/** *正常收费的,原价返回 * @author 我不是张英俊 * */ public class CashNormal extends CashSuper { @Override public double acceptCash( double money) { return money; } } |
4:写一个Context来通过同一个方法进行 不同付费方式的实现。因为需要创建不同的对象,所以需要结合简单工厂模式来实现。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
public class CashContext { private CashSuper cs= null ; public CashContext(String type){ switch (type) { case "正常收费" : CashNormal cs0= new CashNormal(); cs=cs0; break ; case "满300返100" : CashReturn cr1= new CashReturn( "300" , "100" ); cs=cr1; break ; case "打八折" : CashRebate cr2= new CashRebate( "0.8" ); cs=cr2; break ; } } public double GetResult( double money){ return cs.acceptCash(money); } } |
5:测试类
1
2
3
4
5
6
7
8
9
10
11
12
13
|
public class Test { public static void main(String[] args) { double a= new CashContext( "打八折" ).GetResult( 300 ); System.out.println(a); double b= new CashContext( "正常收费" ).GetResult( 300 ); System.out.println(b); double c= new CashContext( "满300返100" ).GetResult( 300 ); System.out.println(c); } } |
6:控制台。
240.0
300.0
200.0
总结:策略模式简化了单元测试,因为每个算法都是自己的类,可以通过自己的接口单独测试。
策略模式是用来封装算法的,但是在实际使用过程中,可以用他来封装几所任何类型的规则,只要在分析过程中听到需要在不同时间应用不同的业务规则,就可以考虑使用策略模式处理这种变化的可能性。
自己感悟:总的来说,策略模式对算法进行了封装,例如功夫熊猫,继承动物的超类之后,既需要有实现语言的功能,又需要实现功夫的功能,使用策略模式,将各个算法分开,在使用的时候可以很好的组合在一起。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/hrlizhi/p/7602193.html