1: 전략 패턴의 정의
전략 패턴은 알고리즘을 패키징한 것으로, 알고리즘 사용 책임을 알고리즘 자체에서 분리하여 이를 다른 객체 관리에 위임합니다. 전략 패턴은 일반적으로 일련의 알고리즘을 추상 전략 클래스의 하위 클래스로 일련의 전략 클래스로 패키징합니다.
클래스 다이어그램은 다음과 같습니다.
전략 패턴을 JAVA 클래스를 사용하여 구현하는 경우 소스 코드는 다음과 같습니다.
Java 코드
/** * * 策略执行 * @author weique.lqf * @version $Id: Context.java, v 0.1 2014-2-9 下午2:32:56 weique.lqf Exp $ */ public class Context { private Strategy stg; public Context(Strategy theStg) { this.stg = theStg; } public void doAction() { this.stg.testStrategy(); } }
전략 인터페이스:
Java代码 /** * * * @author weique.lqf * @version $Id: Strategy.java, v 0.1 2014-2-9 下午2:32:17 weique.lqf Exp $ */ public interface Strategy { void testStrategy(); }
구현 클래스 1:
Java 코드
package com.proxy.strategy.impl; import com.proxy.strategy.Strategy; public class PrintStrategy implements Strategy { public void testStrategy() { System.out.print("我要打印!!"); } }
구현 클래스 2:
Java 코드
package com.proxy.strategy.impl; import com.proxy.strategy.Strategy; public class WriteStrategy implements Strategy { public void testStrategy() { System.out.println("我要写字!!!"); } }
실행 코드:
Java 코드
package com.proxy.strategy; import com.proxy.strategy.impl.PrintStrategy; public class StrategyClient { public static void main(String[] args) { Strategy stgA = new PrintStrategy(); Context ct = new Context(stgA); ct.doAction(); } }
2: spring 구현 전략 모드
현재 Spring을 사용하는 시스템이 너무 많아서 전략을 구현하는 방법 스프링 모드 모직 옷감?
사실 약간의 수정만 필요합니다. Spring의 핵심 중 하나가 IOC이기 때문입니다.
먼저 Contex 클래스를 수정합니다.
Java 코드
package com.proxy.strategy; public class ContextSpring { private Strategy stg; /** * Setter method for property <tt>stg</tt>. * * @param stg value to be assigned to property stg */ public void setStg(Strategy stg) { this.stg = stg; } public void doAction() { this.stg.testStrategy(); } }
그런 다음 spring 구성 파일에서 구성합니다.
Xml 코드
<bean id="ct" class = "com.proxy.strategy.ContextSpring"> <property name="stg" ref="writeStg"/> </bean> <bean id="writeStg" class = "com.proxy.strategy.impl.WriteStrategy"/> <bean id="printStg" class = "com.proxy.strategy.impl.PrintStrategy"/>
삽입하려는 구현 클래스를 선택한 다음 실행된 코드에 다음을 작성합니다.
Java 코드
package com.proxy.strategy; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class StrategySpringClient { public static void main(String[] args) { ApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml"); ContextSpring ct = (ContextSpring) context.getBean("ct"); ct.doAction(); } }
봐, 봄은 이렇게 소개되는구나.
하지만 종류에 따라 지원하려면 장단점이 있습니다. 예를 들어 계약서는 인쇄해야 하고, 러브레터는 손으로 써야 합니다. 계약이 유형 2이고 러브레터가 유형 1이라고 가정할 때 자동으로 적응하려면 어떻게 해야 할까요?
3: 스프링 전략 모드의 고급 버전
먼저 Context 클래스 수정:
Java 코드
package com.proxy.strategy; import java.util.HashMap; import java.util.Map; /** * * * @author weique.lqf * @version $Id: ContextSpringFactory.java, v 0.1 2014-2-9 下午3:46:09 weique.lqf Exp $ */ public class ContextSpringFactory { private Map<String, Strategy> stgMap = new HashMap<String, Strategy>(); /** * Getter method for property <tt>stgMap</tt>. * * @return property value of stgMap */ public Map<String, Strategy> getStgMap() { return stgMap; } /** * Setter method for property <tt>stgMap</tt>. * * @param stgMap value to be assigned to property stgMap */ public void setStgMap(Map<String, Strategy> stgMap) { this.stgMap = stgMap; } public void doAction(String strType) { this.stgMap.get(strType).testStrategy(); } }
그런 다음 spring 구성 파일을 수정합니다.
Xml 코드
<bean id="ctf" class = "com.proxy.strategy.ContextSpringFactory"> <property name="stgMap"> <map> <entry key="1" value-ref="writeStg"/> <entry key="2" value-ref="printStg"/> </map> </property> </bean>
실행된 항목 클래스는 다음과 같이 수정됩니다.
Java 코드
package com.proxy.strategy; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class StrategySpringClientFactory { public static void main(String[] args) { //外部参数 String type = "1"; ApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml"); ContextSpringFactory ctf = (ContextSpringFactory) context.getBean("ctf"); ctf.doAction(type); //type 2 type = "2"; ctf.doAction(type); } }
그런 다음 실행하고 결과가 어떻게 나올지 확인해보세요.