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

doyeol님의 프로필 이미지
doyeol

작성한 질문수

스프링 핵심 원리 - 기본편

주문과 할인 도메인 실행과 테스트

DiscountPolicy 질문 있습니다

작성

·

345

0


[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예

[질문 내용]
Member, Order와 다르게 왜 Discount만 Service 라는 명칭이 없는데요.

 

이 때 MemberService, OrderService 와 같은 Service 역할이지만 단순히 할인정책 이라는 설계 이름때문에 Service가 아닌 Policy로 붙인 건가요?

 

아니면 Discount 부분은 MemberService, OrderService와는 개념적으로 다른 건가요?

답변 1

1

안녕하세요. 유도열님, 공식 서포터즈 David입니다.

후자에 해당합니다.

DiscountPolicy와 *Service 객체들은 서로의 역할과 책임이 다르기 때문입니다.

DiscountPolicy의 구현체들은 할인되어야 하는 금액을 제공하는 것이고

Service Layer에 해당하는 *Service 객체들은 애플리케이션 로직을 캡슐화하는 중간 계층입니다.

Service Layer에 대한 자세한 내용은 아래 글을 참고해 주세요.

https://martinfowler.com/eaaCatalog/serviceLayer.html

감사합니다.


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

객체인 Member와 Order,

인터페이스를 활용한 서비스 계층과 레포지토리 계층 그리고 그걸 구현한 구현체는 이해가 됩니다

그런데 저 DiscountPolicy 인터페이스와 그 구현체는 뭐라고 불러야 할까요?

객체도, 서비스와 레포지토리 계층도 아닌

DiscountPolicy에 대한 명칭과 개념을 잘 모르겠습니다.

DiscountPolicy와 그 구현체들은 가격할인에 대한 책임을 가지고 있는 객체라고 보시면 됩니다.

doyeol님의 프로필 이미지
doyeol

작성한 질문수

질문하기