Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- fp
- SWIFT
- 함수형프로그래밍
- iOS프로그래밍
- 인터페이스
- 이름
- 협업
- 클린코드
- 개발자
- 부스트코스
- 객체지향프로그래밍
- 고차함수
- OOP
- Solid
- Swfit
- 의존성
- 함수형패러다임
- 아이폰프로그래밍
- 문법
- 개발
- 디자인패턴
- 의도
- DesignPattern
- CleanCode
- 클린소프트웨어
- POP
- 네이밍
- IOS
- protocol
- interface
Archives
- Today
- Total
밤에 쓴 코드
Design Pattern) 스트래티지 패턴 본문
스트래티지 패턴
스트래티지 패턴에서는 알고리즘군을 정의하고 각각을 캡슐화하여 교환해서 사용할 수 있도록 만든다. 스트래티지패턴을 활용하면 알고리즘을 사용하는 클라이언트와는 독립적으로 알고리즘을 변경할 수 있다.
문제점
상속
- 일부 적합하지 않은 서브클래스가 존재할 수 있다.
인터페이스
- 인터페이스를 채택한 클래스에서 구현이 이루어진다. 코드의 중복이 야기된다.
디자인 원칙
달라지는 부분과 달라지지 않는 부분을 분리 - 달라지는 부분 캡슐화
인터페이스(상위형식)에 맞추어 프로그래밍
상속보다는 구성(Composition)
개발기간보다 개발이 끝난 후에 코드에 더 많은 시간을 쓴다.
재사용성도 중요하지만 확장성,관리의 용이성이 더 중요하다.
동작이 유연하게 관리되어야 하는 설계에서는 스트래티지 패턴은 좋은 선택이다.
예제코드
Character.java
public abstract class Character {
AttackStrategy attackStrategy;
MoveStrategy moveStrategy;
public Character(AttackStrategy attackStrategy, MoveStrategy moveStrategy) {
this.attackStrategy = attackStrategy;
this.moveStrategy = moveStrategy;
}
public void setMoveStrategy(MoveStrategy moveStrategy) {
this.moveStrategy = moveStrategy;
}
public void move(){
moveStrategy.move();
}
public void attack(){
attackStrategy.attack();
}
}
Gunner.java
public class Gunner extends Character {
public Gunner() {
super(new AttackStrategyWithGun(),new RunStrategy());
}
}
Warrier.java
public class Warrior extends Character{
public Warrior() {
super(new AttackStrategyWithKnife(), new RunStrategy());
}
}
AttackStrategy.java
public interface AttackStrategy {
public void attack();
}
AttackStrategyWithGun.java
public class AttackStrategyWithGun implements AttackStrategy{
@Override
public void attack() {
shoot();
}
// 변화가 있을수 있는 영역
private void shoot(){
System.out.println("총을 쏩니다.");
}
}
AttackStrategyWithKnife.java
public class AttackStrategyWithKnife implements AttackStrategy {
@Override
public void attack() {
swing();
}
// 변화가 있을수 있는 영역
private void swing(){
System.out.println("칼로 공격합니다.");
}
}
MoveStrategy.java
public interface MoveStrategy {
public void move();
}
RunStrategy.java
public class RunStrategy implements MoveStrategy{
@Override
public void move() {
run();
}
// 변화가 있을수 있는 영역
private void run(){
System.out.println("뛰어서 이동합니다.");
}
}
DriveStrategy.java
public class DriveStrategy implements MoveStrategy {
@Override
public void move() {
drive();
}
// 변화가 있을수 있는 영역
private void drive(){
System.out.println("차를 타고 이동합니다.");
}
}
Game.java
public class Game {
public static void main(String[] arg){
Gunner gunner = new Gunner();
gunner.move(); // 뛰어서 이동합니다.
gunner.setMoveStrategy(new DriveStrategy()); // 동작의 변경
gunner.move(); // 차를 타고 이동합니다.
gunner.attack(); // 총으로 공격합니다.
Warrior warrior = new Warrior();
warrior.attack(); // 칼로 공격합니다.
}
}
캐릭터가 걷다가 차를 탈수도 있다. 그럴때 구체적인 클래스를 멤버변수 타입으로 지정했다면 , 유연하게 대처할 수 없었을 것이다.
캐릭터는 계속적으로 추가 될 것이고 , 공격방식이 다양해 질 것이다. 이동방법또한 추가될 수 있다.
그때마다 캐릭터 클래스가 수정되어야 하는가 ?
위와 같은 전략패턴을 이용하면 새로운 전략이 생길 경우 해당 전략의 인터페이스를 구현한 구체클래스를 만들고 인스턴스를 setter를 이용해서 설정만 해주면 새로운 변화에 대해서 유연하게 대처할 수 있다.
UML
'Design Pattern' 카테고리의 다른 글
Design Pattern) 싱글턴 패턴 (0) | 2019.06.23 |
---|---|
Design Pattern) 데코레이터 패턴 (0) | 2019.06.07 |
Design Pattern) 옵저버 패턴 (0) | 2019.05.03 |
Design Pattern) 팩토리 패턴 (0) | 2019.04.29 |
Design Pattern ) 디자인패턴이란? (0) | 2019.04.28 |
Comments