템플릿 메서드 패턴과 콜백 패턴

Gongmeda·2023년 9월 12일
0
post-thumbnail

템플릿 메서드 패턴

템플릿 메서드 패턴(Template Method Pattern)은 다형성을 사용해서 변하지 않는 것(핵심 기능)과 변하는 것(부가 기능)을 분리해서 모듈화할 수 있는 디자인 패턴입니다.

작업에서 알고리즘의 골격을 정의하고 일부 단계를 하위 클래스로 연기합니다. 템플릿 메서드를 사용하면 하위 클래스가 알고리즘의 구조를 변경하지 않고도 알고리즘의 특정 단계를 재정의할 수 있습니다.

핵심 기능 vs 부가 기능

  • 핵심 기능: 객체가 제공하는 고유의 기능
  • 부가 기능: 핵심 기능을 보조하기 위해 제공되는 기능

단점

  • 자식 클래스가 부모 클래스와 컴파일 시점에 강하게 결합되는 문제 (자식 클래스에서 부모 클래스의 기능을 전혀 사용하지 않으면 불필요한 의존 관계가 됨)
  • 상속 구조를 사용하기 때문에, 별도의 클래스나 익명 내부 클래스를 만들어야 해서 복잡함

전략 패턴

템플릿 메서드 패턴과 비슷한 역할을 하면서 상속의 단점을 제거할 수 있는 디자인 패턴이 바로 전략 패턴 (Strategy Pattern)입니다.
전략 패턴은 변하지 않는 부분을 Context 라는 곳에 두고, 변하는 부분을 Strategy 라는 인터페이스를 만들고 해당 인터페이스를 구현하도록 해서 문제를 해결합니다. 상속이 아니라 위임으로 문제를 해결하는 것입니다.
덕분에 Strategy 의 구현체를 변경하거나 새로 만들어도 Context 코드에는 영향을 주지 않습니다.

알고리즘 제품군을 정의하고 각각을 캡슐화하여 상호 교환 가능하게 만들자. 전략을 사용하면 알고리즘을 사용하는 클라이언트와 독립적으로 알고리즘을 변경할 수 있다.

단점

  • ContextStrategy 를 조립한 이후에는 전략을 변경하기가 번거로움 (setter 를 제공해서 Strategy 를 넘겨 받아 변경하면 되지만, Context 를 싱글톤으로 사용할 때는 동시성 이슈 등 고려할 점이 많다)

템플릿 콜백 패턴

다른 코드의 인수로서 넘겨주는 실행 가능한 코드를 콜백(callback)이라 합니다.

프로그래밍에서 콜백(callback) 또는 콜애프터 함수(call-after function)는 다른 코드의 인수로서 넘겨주는 실행 가능한 코드를 말한다. 콜백을 넘겨받는 코드는 이 콜백을 필요에 따라 즉시 실행할 수도 있고, 아니면 나중에 실행할 수도 있다. (위키백과 참고)

자바 언어에서 콜백

  • 자바 언어에서 실행 가능한 코드를 인수로 넘기려면 객체가 필요하다. 자바8부터는 람다를 사용할 수 있다.
  • 자바 8 이전에는 보통 하나의 메소드를 가진 인터페이스를 구현하고, 주로 익명 내부 클래스를 사용했다.
  • 최근에는 주로 람다를 사용한다.

특징

  • 템플릿 콜백 패턴은 GOF 패턴은 아니고, 스프링 내부에서 이런 방식을 자주 사용하기 때문에, 스프링 안에서만 이렇게 부름
  • 전략 패턴에서 템플릿과 콜백 부분이 강조된 패턴이라 생각하면 됨
  • 스프링에서는 JdbcTemplate , RestTemplate , TransactionTemplate , RedisTemplate 처럼 다양한 템플릿 콜백 패턴이 사용됨. 스프링에서 이름에 XxxTemplate 가 있다면 템플릿 콜백 패턴으로 만들어져 있다 생각하면 됨
profile
백엔드 깎는 장인

0개의 댓글