전략 패턴은 여러 알고리즘을 하나의 인터페이스로 추상화하여, 런타임에 알고리즘을 교체할 수 있도록 해주는 패턴이다.
특정 작업을 수행하는 여러 가지 방법이 있을 때, 각각의 방법을 개별 클래스로 분리하여 유연하게 사용하거나 변경할 수 있다.
여러 가지 방식으로 수행할 수 있는 작업이 있을 때, 모든 방식을 한 클래스에 다 넣으면 코드가 복잡해지고 유지보수가 어려워진다.
또한, 알고리즘을 변경해야 할 때마다 코드를 수정해야 하는 문제가 발생할 수 있다. 전략 패턴은 이런 문제를 해결해준다.
예를 들어, 게임 캐릭터가 여러 가지 공격 방식을 가지고 있을 수 있다.
캐릭터가 공격할 때마다 특정 공격 방법을 선택할 수 있도록 구현하고 싶다면, 전략 패턴을 사용하여 각 공격 방법을 별도의 클래스로 분리하고, 캐릭터가 공격 방식을 동적으로 바꾸도록 할 수 있다.
전략 패턴은 다음과 같은 구성 요소로 이루어진다:
Context
└─ Strategy
├─ ConcreteStrategyA
├─ ConcreteStrategyB
이번 예시는 캐릭터(Character)가 여러 가지 공격 방법을 가지고 있는 게임을 구현한다고 가정하자.
캐릭터는 검으로 공격할 수도 있고, 활로 공격할 수도 있으며, 마법을 사용할 수도 있다.
이런 다양한 공격 방법을 전략 패턴을 통해 동적으로 선택할 수 있도록 구현할 것이다.
// 전략 인터페이스
interface AttackStrategy {
void attack();
}
// 구체적인 전략: 검 공격
class SwordAttack implements AttackStrategy {
@Override
public void attack() {
System.out.println("검으로 공격합니다!");
}
}
// 구체적인 전략: 활 공격
class BowAttack implements AttackStrategy {
@Override
public void attack() {
System.out.println("활로 공격합니다!");
}
}
// 구체적인 전략: 마법 공격
class MagicAttack implements AttackStrategy {
@Override
public void attack() {
System.out.println("마법으로 공격합니다!");
}
}
// 컨텍스트: 캐릭터 클래스
class Character {
private AttackStrategy attackStrategy;
// 전략을 설정하는 메서드
public void setAttackStrategy(AttackStrategy attackStrategy) {
this.attackStrategy = attackStrategy;
}
// 공격 메서드: 설정된 전략을 사용하여 공격
public void performAttack() {
if (attackStrategy != null) {
attackStrategy.attack();
} else {
System.out.println("공격 방법이 설정되지 않았습니다.");
}
}
}
// 클라이언트 코드
public class Main {
public static void main(String[] args) {
Character character = new Character();
// 검으로 공격
character.setAttackStrategy(new SwordAttack());
character.performAttack();
// 활로 공격
character.setAttackStrategy(new BowAttack());
character.performAttack();
// 마법으로 공격
character.setAttackStrategy(new MagicAttack());
character.performAttack();
}
}
AttackStrategy
인터페이스는 attack()
메서드를 정의한다. 각 공격 방법은 이 인터페이스를 구현하게 된다.SwordAttack
, BowAttack
, MagicAttack
클래스는 각각 검, 활, 마법으로 공격하는 방법을 구현한 클래스들이다.Character
클래스는 전략을 설정하고 실행하는 역할을 한다. 공격 방식은 setAttackStrategy()
메서드를 통해 동적으로 설정되며, performAttack()
메서드를 호출하면 설정된 전략에 따라 공격이 수행된다.Main
클래스에서 캐릭터 객체를 생성한 후, 여러 가지 공격 방법을 설정하고 이를 실행한다.검으로 공격합니다!
활로 공격합니다!
마법으로 공격합니다!
전략 패턴(Strategy Pattern)은 다양한 알고리즘을 동적으로 적용해야 하는 경우에 유용한 패턴이다.
특히 게임과 같은 시나리오에서 캐릭터의 다양한 공격 방식을 구현할 때, 이 패턴을 사용하면 코드의 유연성과 확장성을 높일 수 있다.
아래 글에서 다른 디자인 패턴들을 확인할 수 있다.
디자인 패턴 모음