Form Template Method
각각의 서브 클래스에, 동일한 순서로 비슷한 단계를 행하지만 단계가 완전히 같지는 않은 두 메소드가 있다면,
그 단계를 동일한 시그너처를 가진 메소드로 만들어라.
이렇게 하면 원래의 두 메소드는 서로 같아지므로, 수퍼클래스로 올릴 수 있다.
상속을 통해서 중복을 제거할 때 서브 클래스들에 있는 비슷한 메소드들을 본질적인 차이점만을 남겨놓고 중복을 제거할 수 있다. 이와 관련된 패턴으로 Template Method 패턴이 있다.
절차
1. 메소드를 분해해서 동일 한 부분과 다른 부분을 나눈다.
2. 동일한 부분을 Pull Up Method를 사용하여 수퍼클래스로 올린다.
3. 다른 부분을 정의한 메소드를 수퍼클래스에서 추상 메소드로 선언한다.
4. 서브 클래스에는 다른 부분을 정의한 메소드를 제외하고 모두 제거한다.
5. 각 단계마다 컴파일, 테스트를 한다.
예제
예제 코드는 Extract Superclass에서 사용했던 코드를 그대로 사용합니다.
0. Extract Superclass로 상위 클래스를 만듭니다.
1. 메소드를 고정적인 부분과 유동적인 부분으로 분해합니다.
- before
- Alt + Shift + M 을 사용하여 메소드로 빼낼 수 있습니다.
- after
2. Pull Up Method를 사용하여 공통된 부분을 상위 클래스로 옮깁니다.
- 이 때 Alt + Shift + T 로 리팩토링 메뉴를 열고 Pull Up Method를 사용할 수 있습니다.
3. 수퍼클래스에서 추상 메소드로 변경되는 내용을 지닌 메소드를 만들어 줍니다.
- 변경되는 부분의 메소드가 올라가지 않았기 때문에 수퍼클래스에서 에러가 납니다. 에러가 발생한 라인에서 퀵 픽스(Ctrl + 1)를 사용하여 만들 수 있습니다.
- abstract protected void doService(Task task);
메소드에 abstract를 붙여주면 클래스도 추상 클래스가 되어야 하며 그럼 추상 클래스의 이름 앞에도 Abstract를 붙여주는 것이 좋겠습니다. Package Explorer에서 클래스르 선택하고 F2 를 클릭하여 클래스 이름을 변경할 수 있습니다.
4. 서브클래스를 정리합니다.
- 현재 작업한 서브 클래스는 전부 변경이 되었겠지만 다른쪽 서버클래스는 별다른 작업이 없었기 때문에 공통 부분을 제거하고 추상 메소드를 구현해 줍니다. 이때도 퀵 픽스를 사용하면 편리합니다.