템플릿 메서드 패턴(Template Method Pattern)은 다형성을 사용해서 변하지 않는 것(핵심 기능)과 변하는 것(부가 기능)을 분리해서 모듈화할 수 있는 디자인 패턴입니다.
작업에서 알고리즘의 골격을 정의하고 일부 단계를 하위 클래스로 연기합니다. 템플릿 메서드를 사용하면 하위 클래스가 알고리즘의 구조를 변경하지 않고도 알고리즘의 특정 단계를 재정의할 수 있습니다.
템플릿 메서드 패턴과 비슷한 역할을 하면서 상속의 단점을 제거할 수 있는 디자인 패턴이 바로 전략 패턴 (Strategy Pattern)입니다.
전략 패턴은 변하지 않는 부분을 Context
라는 곳에 두고, 변하는 부분을 Strategy
라는 인터페이스를 만들고 해당 인터페이스를 구현하도록 해서 문제를 해결합니다. 상속이 아니라 위임으로 문제를 해결하는 것입니다.
덕분에 Strategy
의 구현체를 변경하거나 새로 만들어도 Context
코드에는 영향을 주지 않습니다.
알고리즘 제품군을 정의하고 각각을 캡슐화하여 상호 교환 가능하게 만들자. 전략을 사용하면 알고리즘을 사용하는 클라이언트와 독립적으로 알고리즘을 변경할 수 있다.
Context
와 Strategy
를 조립한 이후에는 전략을 변경하기가 번거로움 (setter 를 제공해서 Strategy
를 넘겨 받아 변경하면 되지만, Context
를 싱글톤으로 사용할 때는 동시성 이슈 등 고려할 점이 많다)다른 코드의 인수로서 넘겨주는 실행 가능한 코드를 콜백(callback)이라 합니다.
프로그래밍에서 콜백(callback) 또는 콜애프터 함수(call-after function)는 다른 코드의 인수로서 넘겨주는 실행 가능한 코드를 말한다. 콜백을 넘겨받는 코드는 이 콜백을 필요에 따라 즉시 실행할 수도 있고, 아니면 나중에 실행할 수도 있다. (위키백과 참고)
JdbcTemplate
, RestTemplate
, TransactionTemplate
, RedisTemplate
처럼 다양한 템플릿 콜백 패턴이 사용됨. 스프링에서 이름에 XxxTemplate 가 있다면 템플릿 콜백 패턴으로 만들어져 있다 생각하면 됨