设计模式(DesignPattern)之策略模式(Stragety)

本文详细介绍了策略模式的概念、使用场景及其实现方式,并通过一个简单的计算器示例展示了如何使用策略模式来选择不同的算法策略。

1、定义

        分别封装行为接口,超类存放行为接口对象,在子类里设定具体的行为对象,换句话说,就是定义了一系列行为的接口,在使用者的超类中持有此接口类型的对象,在具体的使用者设置具体的行为对象,达到使用不同策略的目的。

2、使用场景

        1、针对同一种问题有不同的解决方式,不同的解决方式之间可以互换,不会造成影响。

        2、当出现if-else判断语句来选择具体的行为对象的时候可以考虑策略模式。

3、UML类图

        

4、代码实现

        
 

/**
 * 定义算法接口
 */
public interface IAlgorithm {

    int calculate(int a, int b);

}

/**
 * 减法运算策略
 */
public class Minus implements IAlgorithm {

    @Override
    public int calculate(int a, int b) {
        return a - b;
    }

}

/**
 * 加法运算策略
 */
public class Plus implements IAlgorithm {
    @Override
    public int calculate(int a, int b) {
        return a + b;
    }
}

/**
 * 充当Context的角色
 */
public class Calculator {

    private IAlgorithm algorithm;

    /**
     * 选择不同的策略
     * @param algorithm
     */
    public void setAlgorithm(IAlgorithm algorithm) {
        this.algorithm = algorithm;
    }

    /**
     * 根据不同策略来实现不同的算法
     * @param a
     * @param b
     * @return
     */
    public int calculate(int a, int b) {
        return algorithm.calculate(a, b);
    }

}

public class MainTest {

    public static void main(String[] args) {
        Calculator calculator = new Calculator();
        //选择不同的策略
        calculator.setAlgorithm(new Minus());
        calculator.calculate(1, 2);
    }

}

5、总结

        优点:1、不同策略之间互不影响,完全可以互换,能够很好的解耦合,扩展性好。

                  2、具有良好的封装,结构简单清晰,便于维护不同的策略。

        缺点:造成类的增多。

        总的来说,策略模式你叫简单,但是要区别于模板方法模式,模板方法模式是定义莫一种算法的整体框架,其中关键的部分让子类去实现,采用的是继承的方式,而策略模式定义的是一系列算法,算法之间相互独立,可以互相替换而不会造成影响,采用的是组合的方式来时。

6、在Android源码中的应用

      Android动画插值器。

代码:https://gitee.com/os2chen/DesignPattern

 

 

参考:《Head First Design》、《Android源码设计模式解析与实战》

 

### MyBatis Update 策略的使用与配置 MyBatis 是一种优秀的持久层框架,它支持定制化 SQL 查询、存储过程以及高级映射。对于 `update` 操作而言,MyBatis 提供了多种方式来实现更新操作并允许开发者灵活控制。 #### 使用 XML 映射文件定义 Update 语句 在 Mapper XML 文件中可以直接编写 SQL 的 UPDATE 语句: ```xml <update id="updateUser" parameterType="map"> UPDATE users SET name = #{name}, email = #{email} WHERE id = #{id} </update> ``` 此段代码展示了如何通过传递参数来进行条件性的数据修改[^1]。 #### 动态 SQL 更新 当面对复杂的业务逻辑时,可能需要构建动态 SQL 来适应不同的情况。MyBatis 支持 `<if>`, `<choose>` (类似于 switch), `<when>, <otherwise>` 和其他标签用于创建更加智能的查询语句: ```xml <update id="dynamicUpdateUser" parameterType="map"> UPDATE users <set> <if test="name != null">name=#{name}, </if> <if test="email != null">email=#{email}</if> </set> WHERE id = #{id} </update> ``` 上述例子说明了只有当特定字段不为空的时候才会被加入到设置列表里去进行更新。 #### 利用注解方式进行简单的更新操作 除了基于 XML 配置外,还可以采用 Java 注解的方式来简化 CRUD 方法声明: ```java @Update("UPDATE users SET name=#{name} , email=#{email} WHERE id=#{id}") int updateUser(@Param("id") int userId, @Param("name") String userName, @Param("email") String userEmail); ``` 这种方式适合于较为简单的场景下快速完成数据库表记录的更改工作。 #### 自动填充时间戳或其他默认值 有时希望某些列能够在每次更新时自动获取当前的时间戳或者其他预设好的初始值。这可以通过自定义拦截器或者利用插件机制来达成目的。例如,在应用层面可以考虑集成 P6Spy 工具配合 Spring Boot 实现细粒度的日志跟踪和性能监控[^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值