Part III: Refactoring Toward Deeper Insight
Levels of Refactoring
리팩터링의 목표는 개발자가 단순히 코드가 수행하는 바를 이해하는 것뿐만 아니라
왜 그렇게 수행되는지를 이해하고 도메인 전문가와의 의사소통에 이를 연관시키는 것이다.
Deep Models
도메인의 피상적1)인 측면은 배제하고
도메인 전문가의 주요 관심사와 가장 적절한 지식을 알기 쉽게 표현하는 모델이다.
이 정의가 추상화를 의미하는 것은 아니다.
심층 모델이 일반적으로 추상적인 요소를 포함하기는 하지만
문제의 핵심을 관통하는 구체적인 요소 또한 포함할 수 있다.
도메인과 조화를 이루는 모델에서는 융통성, 단순함, 설명력을 얻을 수 있다.
그러한 모델이 공통적으로 지니고 있는 한 가지 특징은 업무 전문가가 즐겨 쓰는 단순하지만 충분히 추상적인 언어가 존재한다는 것이다.
Deep Model/Supple Design
Supple Design은 변경을 촉진할 뿐 아니라 모델 자체의 개선에도 기여한다.
Model-Driven Design을 지탱하는 두 개의 축이 있다.
심층 모델은 ①설계의 표현력을 부여한다.
그와 동시에 개발자가 여러 가지 시도를 할 수 있을 정도로 설계가 유연하고
개발자가 무슨 일이 일어나고 있는지 파악할 수 있을 만큼 설계가 명확하다면
②모델의 발견 과정에 통찰력을 제공할 수 있다.
The Discovery Process