인프런 커뮤니티 질문&답변

woowang님의 프로필 이미지
woowang

작성한 질문수

스프링 핵심 원리 - 기본편

스프링으로 전환하기

회원등급이 추가되면 OCP 위반인가요?

작성

·

492

0

안녕하세요!
문득 궁금증이 생겨서 질문합니다.

예제에서는 Basic, VIP 이렇게 2개의 회원등급이 enum에 존재하고 DiscountPolicy 구현클래스는 각 등급에 따른 분기로 할인정도를 조절합니다. (VIP의 경우 10%할인, 1000원 할인)
만약 회원등급이 추가된다면 DiscountPolicy 구현클래스의 코드를 모두 수정해야 하는데, 이 경우 OCP위반이라고 하나요?
아니면 어쩔 수 없는 비즈니스 로직이 변경된 경우인가요?

답변 2

1

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. woowang님

여기서는 할인 정책에 대해서 OCP 원칙이 적용되어 있습니다. 그래서 할인 정책이 추가되는 경우 기존 코드를 손대지 않고, 확장이 가능합니다.

반면에 회원의 등급에 대해서는 처음부터 OCP원칙이 적용되어 있지 않습니다. 따라서 OCP 원칙을 위반한다고 볼 수 있습니다.

소프트웨어 개발에서 모든 곳에 OCP원칙을 적용하는 것이 꼭 좋은 방법은 아닙니다. OCP 원칙을 도입하려면 인터페이스도 추가해야 하고, 추상화를 해야 하기 때문입니다. 단순한 IF문 하나로 문제를 해결할 수 있는데, 복잡하게 추상화 비용이 들어가는 것이지요. 따라서 이러한 트레이드 오프를 넘을 때 OCP 원칙을 도입하는 것이 좋습니다. 쉽게 이야기해서 기존 코드를 변경하지 않고, 자주 확장을 해야 하는 곳에 부분적으로 도입하는 것이 좋습니다.

감사합니다.

woowang님의 프로필 이미지
woowang
질문자

좋은 답변 감사합니다!
트레이드 오프를 따져보고 도입하는게 바람직하군요

항상 좋은 강의 감사합니다!

0

woowang님의 프로필 이미지
woowang
질문자

OCP에서 말하는 확장은 구현체의 확장만을 의미하는 건가요?
(카드 가맹을 예로 들면 국민카드, 현대카드의 구현체만 있었는데 새롭게 하나카드 구현체가 추가되는 경우)

김영한님의 프로필 이미지
김영한
지식공유자

네 맞습니다. 기존 코드의 변경 없이 구현체를 확장하는 것을 뜻합니다.

감사합니다.

woowang님의 프로필 이미지
woowang

작성한 질문수

질문하기