zoukankan      html  css  js  c++  java
  • 设计模式-策略模式

    设计模式-策略模式
    以计算器为栗

    最直接加减法

    public class Calculator{
    	// 加符号
    	private final static String ADD_SYMBOL = "+";
    	// 减符号
    	private final static String SUB_SYMBOL = "-";
    	// 执行
    	public int exec(int a, int b, String symbol){
    		int result = 0;
    		if(symbol.equals(ADD_SYMBOL)){	// 比较
    			result = this.add(a,b);
    		}else if(symbol.equals(SUB_SYMBOL)){
    			result = this.sub(a,b);
    		}
    	}
    	// 加法
    	public int add(int a, int b){
    		return a + b;
    	}
    	// 减法
    	public int sub(int a, int b){
    		return a - b;
    	}
    }
    

    书写场景类

    public class Client{
    	public static void main(String[] args){
    		// 获取输入
    		int a = Integer.parseInt(args[0]);
    		int b = Integer.parseInt(args[1]);
    		// 生成运算器
    		Calculator calculator = new Calculator();
    		calculator.exec(a,b);
    	}
    }
    

    引入策略模式

    即,将原先的加减法进行拆分
    引入策略模式

    protected interface Calculator{
    	public int exec(int a, int b);
    }
    

    书写具体策略

    public class Add implements Calculator{
    	// 加法
    	@Overrider
    	public int exec(int a, int b){
    		return a + b;	
    	}
    }
    

    书写减法运算

    public class Sub implements Calculator{
    	// 减法
    	public int exec(int a, int b){
    		return a - b;
    	}
    }
    

    why?为什么要进行封装,因为保证可以随时的增加具体的策略,所以需要一个上下文。

    public class Context{
    	private Calculator cal = null;
    	// 通过构造函数注入
    	public Context(Calculator _cal){
    		this.cal = _cal;	// 完成指向
    	}
    	// 执行
    	public int exec(int a, int b){
    		return this.cal.exec(a,b);
    	}
    }
    

    场景

    public class Client{
    	// 加
    	public final static String ADD_SYMBOL = "+";
    	// 减
    	public final static String SUB_SYMBOL = "-";
    	public static void main(String[] args){
    		int a = Integer.parseInt(args[0]);
    		String symbol = args[1];
    		int b = Integer.parseInt(args[2]);
    		// 初始化上下文
    		Context context = null;
    		// 选择策略
    		if(symbol.equals(ADD_SYMBOL)){
    			context = new Context(new Add());
    		}else if(symbol.equals(SUB_SYMBOL)){
    			context = new COntext(new SUb());
    		}
    		// 结果
    		context.exec(a,b);
    	}
    }
    

    使用枚举

    public enum Calculator{
    	// 枚举成员
    	// 加法枚举
    	ADD("+"){
    		public int exec(int a, int b){
    			return a + b;
    		}
    	}
    	// 减法枚举
    	SUB("-"){
    		public int exec(int a, int b){
    			return a - b;	
    		}	
    	}
    	// 定义类型
    	String value = "";
    	// 构造
    	private Calculator(String _value){
    		this.value = _value;
    	}
    	// get
    	public String getValue(){
    		return this.value;
    	}
    	// 预留扩展
    	public abstract int exec(int a. int b);
    }
    

    最后书写场景

    public class Client{
    	public static void main(String[] args){
    		int a = Integer.parseInt(args[0]);
    		String symbol = args[1];
    		int b = Integer.parseInt(args[2]);
    		Calculator.ADD.exec(a, b);
    	}
    }
    

    总结

    将原先耦合的if进行拆分成类,然后使用的时候注入类即可。或者使用枚举类型,如果需要增加,需要实现抽象方法。

    应用

    动画的实现,将各种缓动函数,书写为策略模式,然后使用的时候,将类注入即可。
    表单校验,同样可以将各种校验进行解耦,使用的时候注入即可。

    在无知的道路上缓步前行
  • 相关阅读:
    .net core 3.1 添加区域 area
    JMeter 网站并发测试工具使用教程
    .net core 3.1 使用ado.net
    .net core 3.1 mvc 调试的时 更改cshtml页面 刷新浏览器不更新
    .net core 3.1 autofac(webapi / mvc 通过)
    .net core3.1 rest api 无法接收 vue 中 axios 请求
    .net core 3.1 web api 允许跨域
    mysql 中文匹配
    mysql 分组排序
    mysql json处理
  • 原文地址:https://www.cnblogs.com/melovemingming/p/10085231.html
Copyright © 2011-2022 走看看