设计模式之策略模式【Stragety Pattern】

本文介绍了策略模式的概念、使用场景及其实现方法。策略模式允许在运行时选择算法,从而避免使用复杂的条件判断语句。文中还提供了策略模式的具体实现示例,并以Android动画的时间插值器为例说明其应用。

当一个问题有多个不同的解决方案时,可以考虑使用策略模式。

1、定义

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

2、使用场景

  • 当同一类型的问题有多种处理方式,而仅仅是具体的行为有差别时。
  • 出现同一个算法,有多种不同的实现情况时,可以使用策略模式来把这些“不同的实现”实现成为一个算法的类层次。
  • 出现同一抽象类有多个子类,而又需要使用 if-else 或者 switch-case 来选择具体子类时。
  • 出现抽象一个定义了很多行为的类,而又需要使用 if-else 或者 switch-case 来选择行为时。

3、UML图

这里写图片描述

4、示例代码

public interface Stragety {
    /**
     * 算法接口
     */
    void algorithm();
}

public class ConcreteStragetyA implements Stragety {

    @Override
    public void algorithm() {
        System.out.println("算法A");
    }
}

public class ConcreteStragetyB implements Stragety {

    @Override
    public void algorithm() {
        System.out.println("算法B");
    }
}

public class Context {
    private Stragety stragety;

    public Context(Stragety stragety) {
        super();
        this.stragety = stragety;
    }

    public void operation() {
        //使用具体的策略对象进行算法进行运算
        stragety.algorithm();
    }
}

策略模式主要用来分离算法,在相同的行为抽象下有不同的具体实现策略。
策略模式的本质是:分离算法,选择实现。

5、Android 源码中的策略模式

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]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值