해결된 질문
작성
·
433
답변 1
3
안녕하세요, annjae4676 님! 공식 서포터즈 codesweaver 입니다.
적절한 추상화는 설계의 유연함을 갖습니다.
그러나 지나친 추상화는 모호합니다. 설계의 의도를 알 수 없게 합니다.
만약 어떤 메서드가 boolean 을 반환한다면, ' 이 메서드는 참 또는 거짓을 판별한다'고 추측할 수 있습니다. 메서드는 boolean 외에 다른 정보를 반환할 수 없습니다. 구체적이고 명확하지만 유연함이 떨어지죠.
반환값을 한 단계 추상화 해서 ResultMessage 객체로 반환하면 어떨까요? ResultMessage는 메서드의 실행결과(boolean), 실행 결과를 설명하는 메시지(String), 실행 후 결과값(Object)를 갖습니다. 적절하게 유연하면서 어느정도 의미를 예측할 수 있습니다.
이제 또 한 단계 추상화해서 메서드가 Object를 반환한다고 하면 어떨까요? 메서드를 사용하는 사람은 Object가 무슨 값인지 전혀 알 수 없습니다. 메서드의 내용을 따라 가면서 무슨 값인지 찾아야 합니다. 이는 지나친 추상화의 예입니다.
항상 인터페이스를 두어 유연함을 가져갈 필요는 없습니다. 필요한 곳에 필요한 만큼 유연하면 됩니다. 그리고 '어느 정도의 유연함이 적절한가'를 알기 위해선 경험이 필요합니다.
감사합니다.