专业的JAVA编程教程与资源

网站首页 > java教程 正文

动手写一个策略模式(Java版)(java策略模式优化ifelse)

temp10 2024-09-30 00:29:57 java教程 201 ℃ 0 评论

策略模式的定义与特点

策略(Strategy)模式的定义:该模式定义了一系列算法,并将每个算法封装起来,使它们可以相互替换,且算法的变化不会影响使用算法的客户。策略模式属于对象行为模式,它通过对算法进行封装,把使用算法的责任和算法的实现分割开来,并委派给不同的对象对这些算法进行管理。

策略模式的主要优点如下。

动手写一个策略模式(Java版)(java策略模式优化ifelse)

  1. 多重条件语句不易维护,而使用策略模式可以避免使用多重条件语句,如 if...else 语句、switch...case 语句。
  2. 策略模式提供了一系列的可供重用的算法族,恰当使用继承可以把算法族的公共代码转移到父类里面,从而避免重复的代码。
  3. 策略模式可以提供相同行为的不同实现,客户可以根据不同时间或空间要求选择不同的。
  4. 策略模式提供了对开闭原则的完美支持,可以在不修改原代码的情况下,灵活增加新算法。
  5. 策略模式把算法的使用放到环境类中,而算法的实现移到具体策略类中,实现了二者的分离。


其主要缺点如下。

  1. 客户端必须理解所有策略算法的区别,以便适时选择恰当的算法类。
  2. 策略模式造成很多的策略类,增加维护难度。

策略模式的应用场景

策略模式在很多地方用到,如 Java SE 中的容器布局管理就是一个典型的实例,Java SE 中的每个容器都存在多种布局供用户选择。在程序设计中,通常在以下几种情况中使用策略模式较多。

  1. 一个系统需要动态地在几种算法中选择一种时,可将每个算法封装到策略类中。
  2. 一个类定义了多种行为,并且这些行为在这个类的操作中以多个条件语句的形式出现,可将每个条件分支移入它们各自的策略类中以代替这些条件语句。
  3. 系统中各算法彼此完全独立,且要求对客户隐藏具体算法的实现细节时。
  4. 系统要求使用算法的客户不应该知道其操作的数据时,可使用策略模式来隐藏与算法相关的数据结构。
  5. 多个类只区别在表现行为不同,可以使用策略模式,在运行时动态选择具体要执行的行为。

策略模式的结构与实现

策略模式是准备一组算法,并将这组算法封装到一系列的策略类里面,作为一个抽象策略类的子类。策略模式的重心不是如何实现算法,而是如何组织这些算法,从而让程序结构更加灵活,具有更好的维护性和扩展性,现在我们来分析其基本结构和实现方法。

1. 模式的结构

  1. 抽象策略(Strategy)类:定义了一个公共接口,各种不同的算法以不同的方式实现这个接口,环境角色使用这个接口调用不同的算法,一般使用接口或抽象类实现。
  2. 具体策略(Concrete Strategy)类:实现了抽象策略定义的接口,提供具体的算法实现。
  3. 环境(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();
		
		
	}

}

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表