网站首页 > java教程 正文
策略模式的定义与特点
策略(Strategy)模式的定义:该模式定义了一系列算法,并将每个算法封装起来,使它们可以相互替换,且算法的变化不会影响使用算法的客户。策略模式属于对象行为模式,它通过对算法进行封装,把使用算法的责任和算法的实现分割开来,并委派给不同的对象对这些算法进行管理。
策略模式的主要优点如下。
- 多重条件语句不易维护,而使用策略模式可以避免使用多重条件语句,如 if...else 语句、switch...case 语句。
- 策略模式提供了一系列的可供重用的算法族,恰当使用继承可以把算法族的公共代码转移到父类里面,从而避免重复的代码。
- 策略模式可以提供相同行为的不同实现,客户可以根据不同时间或空间要求选择不同的。
- 策略模式提供了对开闭原则的完美支持,可以在不修改原代码的情况下,灵活增加新算法。
- 策略模式把算法的使用放到环境类中,而算法的实现移到具体策略类中,实现了二者的分离。
其主要缺点如下。
- 客户端必须理解所有策略算法的区别,以便适时选择恰当的算法类。
- 策略模式造成很多的策略类,增加维护难度。
策略模式的应用场景
策略模式在很多地方用到,如 Java SE 中的容器布局管理就是一个典型的实例,Java SE 中的每个容器都存在多种布局供用户选择。在程序设计中,通常在以下几种情况中使用策略模式较多。
- 一个系统需要动态地在几种算法中选择一种时,可将每个算法封装到策略类中。
- 一个类定义了多种行为,并且这些行为在这个类的操作中以多个条件语句的形式出现,可将每个条件分支移入它们各自的策略类中以代替这些条件语句。
- 系统中各算法彼此完全独立,且要求对客户隐藏具体算法的实现细节时。
- 系统要求使用算法的客户不应该知道其操作的数据时,可使用策略模式来隐藏与算法相关的数据结构。
- 多个类只区别在表现行为不同,可以使用策略模式,在运行时动态选择具体要执行的行为。
策略模式的结构与实现
策略模式是准备一组算法,并将这组算法封装到一系列的策略类里面,作为一个抽象策略类的子类。策略模式的重心不是如何实现算法,而是如何组织这些算法,从而让程序结构更加灵活,具有更好的维护性和扩展性,现在我们来分析其基本结构和实现方法。
1. 模式的结构
- 抽象策略(Strategy)类:定义了一个公共接口,各种不同的算法以不同的方式实现这个接口,环境角色使用这个接口调用不同的算法,一般使用接口或抽象类实现。
- 具体策略(Concrete Strategy)类:实现了抽象策略定义的接口,提供具体的算法实现。
- 环境(Context)类:持有一个策略类的引用,最终给客户端调用。
示例1通过接口实现
/**
* @describe 抽象策略(Strategy)类,用于定义具体的算法,
* Used to define Algorithms
* @author 79197
*
*/
public interface StrategyInterface {
//策略方法
public void strategyMethod();
}
//具体策略类A specifice strategy class A
public class StrategyA implements StrategyInterface{
@Override
public void strategyMethod() {
System.out.println("this is StrategyA;");
}
}
//具体策略类A specifice strategy class B
public class StrategyB implements StrategyInterface{
@Override
public void strategyMethod() {
System.out.println("this is StrategyB;");
}
}
/**
* @describe 这个类主要用于引用策略类,创建具体的策略对象,为客户端提供调用接口
* This class is mainly used to reference strategy(policy) classes;
* Create a specific policy object
* provide calling interface for client
* @author 79197
*
*/
public class ContextInterface {
//聚合,引用策略对象
private StrategyInterface strategyInterfaceObj;
public StrategyInterface getStrategyInterfaceObj() {
return strategyInterfaceObj;
}
public void setStrategyInterfaceObj(StrategyInterface strategyInterfaceObj) {
this.strategyInterfaceObj = strategyInterfaceObj;
}
//策略方法的具体实现
//specific implements class of strategy method
public void strategyMethod() {
strategyInterfaceObj.strategyMethod();
}
}
示例2通过抽象类实现
//抽象策略,该类中定义策略方法,供子类重定义
abstract class StrategyAbstract {
//策略方法
abstract void strategyMethod();
}
//具体策略方法,specific policy method
public class StrategyAbstractA extends StrategyAbstract{
//具体的策略方法 specific method of strategy class
@Override
void strategyMethod() {
System.out.println("this is StrategyAbstractA;");
}
}
//this is specific implements class,provide specific policy method
public class StrategyAbstractB extends StrategyAbstract{
@Override
void strategyMethod() {
// TODO Auto-generated method stub
System.out.println("this is StrategyAbstractB;");
}
}
/**
* 环境类 context class (Environment)
* @describe 这个类主要用于引用策略类,创建具体的策略对象,为客户端提供调用接口
* This class is mainly used to reference policy classes;strategy
* Create specific policy object
* provide calling interface for client
* @author 79197
*
*/
public class ContextAbstract {
StrategyAbstract strategyAbstractObj;
public StrategyAbstract getStrategyAbstractObj() {
return strategyAbstractObj;
}
public void setStrategyAbstractObj(StrategyAbstract strategyAbstractObj) {
this.strategyAbstractObj = strategyAbstractObj;
}
public void strategyMethod() {
strategyAbstractObj.strategyMethod();
}
}
测试类
public class StrategyTest {
public static void main(String[] args) {
//通过接口的方式实现Implemented by interface class
ContextInterface obj01=new ContextInterface();
StrategyInterface objA=new StrategyA();
obj01.setStrategyInterfaceObj(objA);
obj01.strategyMethod();
StrategyInterface objB=new StrategyB();
obj01.setStrategyInterfaceObj(objB);
obj01.strategyMethod();
//通过抽象类实现 Implemented by abstract class
ContextAbstract obj2=new ContextAbstract();
StrategyAbstract objAbstractA=new StrategyAbstractA();
obj2.setStrategyAbstractObj(objAbstractA);
obj2.strategyMethod();
StrategyAbstract objAbstractB=new StrategyAbstractB();
obj2.setStrategyAbstractObj(objAbstractB);
obj2.strategyMethod();
}
}
猜你喜欢
- 2024-09-30 Java策略模式在动态数据验证中的应用
- 2024-09-30 《设计模式》之策略模式(策略设计模式详解)
- 2024-09-30 Spring 中策略模式的 2 个经典应用
- 2024-09-30 Java策略模式实现动态验证不同来源的数据
- 2024-09-30 策略模式介绍以及具体使用场景(策略模式的优点及适用环境)
- 2024-09-30 什么是策略模式(策略模式的意图是什么)
- 2024-09-30 设计模式系列—策略模式(策略模式实现)
- 2024-09-30 快速带你彻底弄懂23种设计模式-策略模式
- 2024-09-30 「java设计模式」(7)——策略模式(案例解析)
- 2024-09-30 使用 Java 的策略设计模式(在java中找一个应用策略模式的实例)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)