회원등급이 추가되면 OCP 위반인가요?
574
작성한 질문수 3
안녕하세요!
문득 궁금증이 생겨서 질문합니다.
예제에서는 Basic, VIP 이렇게 2개의 회원등급이 enum에 존재하고 DiscountPolicy 구현클래스는 각 등급에 따른 분기로 할인정도를 조절합니다. (VIP의 경우 10%할인, 1000원 할인)
만약 회원등급이 추가된다면 DiscountPolicy 구현클래스의 코드를 모두 수정해야 하는데, 이 경우 OCP위반이라고 하나요?
아니면 어쩔 수 없는 비즈니스 로직이 변경된 경우인가요?
답변 2
1
안녕하세요. woowang님
여기서는 할인 정책에 대해서 OCP 원칙이 적용되어 있습니다. 그래서 할인 정책이 추가되는 경우 기존 코드를 손대지 않고, 확장이 가능합니다.
반면에 회원의 등급에 대해서는 처음부터 OCP원칙이 적용되어 있지 않습니다. 따라서 OCP 원칙을 위반한다고 볼 수 있습니다.
소프트웨어 개발에서 모든 곳에 OCP원칙을 적용하는 것이 꼭 좋은 방법은 아닙니다. OCP 원칙을 도입하려면 인터페이스도 추가해야 하고, 추상화를 해야 하기 때문입니다. 단순한 IF문 하나로 문제를 해결할 수 있는데, 복잡하게 추상화 비용이 들어가는 것이지요. 따라서 이러한 트레이드 오프를 넘을 때 OCP 원칙을 도입하는 것이 좋습니다. 쉽게 이야기해서 기존 코드를 변경하지 않고, 자주 확장을 해야 하는 곳에 부분적으로 도입하는 것이 좋습니다.
감사합니다.
코드 자료
0
50
2
구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?
0
56
2
MemberService의 인터페이스를 왜 사용하는지 궁금합니다.
0
77
1
롬복 @Setter를 써야 하는 상황이 있는건가요?
0
92
1
빈 등록 메서드의 파라미터가 빈이 아니어도 되나요?
0
81
1
테스트 속도가 나중에 영향이 있을까요?
0
77
1
gradle 설정 안떠서 질문 남깁니다!
0
122
2
build.gradle로 프로젝트를 여는 이유
0
87
1
provider 사용하는 이유
0
90
1
다음 강의 뭘 들어야 할까요
0
126
2
프로토타입 빈, 직접 destroy 호출 안 할 경우
0
66
1
beanB
0
82
2
퀴즈다시풀기
0
69
1
Gradle로 바꿔도 오류가 똑같이 발생하네요 ㅠㅠ
0
92
2
"중복 등록과 충돌" 강의에서 강사님과 다른 에러가 발생합니다.
0
67
3
run 실행했는데 결과창이 이렇게 뜨네요 왜 그런건가요>
0
106
2
도메인의 정의?
0
59
1
ApplicationContext 질문입니다.
0
63
1
@Scope의 proxyMode를 사용할때 단위 테스트 방법
0
90
2
ai api 선정하기 관련 질문
0
118
2
생성자 자동주입 관련해서
0
66
1
생성자 직접 호출 vs 팩토리 메서드 패턴
0
97
2
Spring에서 SessionScope와 RequestScope는 함께 사용되나요?
1
66
1
12:25
0
79
2





