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

cjswoudddn님의 프로필 이미지
cjswoudddn

작성한 질문수

자바 ORM 표준 JPA 프로그래밍 - 기본편

상속 타입 설계 질문드립니다!!

작성

·

193

0

안녕하세요 존경하는 영한선생님!

우선 모든 강좌 너무 유익하게 잘 보있는 점 감사드립니다!!

토이프로젝트를 진행 중 상속값 타입을 사용하기로 결정했고

그에 따른 객체지향 설계에 고민이 생겨서 질문드립니다!

우선 부모타입은 join전략을 선택한 Portfolio입니다.

여기서 다양한 양식의 하위 포트폴리오 타입을 추가하려고 합니다.

다만 생성일자와 수정일자는 공통으로 갖도록 설계하였습니다.

front에서 폼 양식을 보냈을 때 컨트롤러에서 dto를 받는 방법을 생각했습니다.

1. 양식 별로 dto와 메소드를 만든다

2. 추상화된 dto를 통해 한 메소드에서 모든 처리를 한다.

저는 2번을 선택했고 Map을 통해 처리하였습니다.

이제 서비스에서 도메인에게 도메인 생성을 위임하고 다시 도메인은 팩토리 메소드를 통해 

구체클래스 생성을 위임했습니다.

이렇게 하면 추가적인 템플릿 양식이 늘어나더라도 변하는 부분을 팩토리 코드 하나만으로 줄였습니다.

다만, 결국 팩토리 코드 자체는 변경에 닫혀 있지 못한 코드가 되었는데

더 좋은 디자인 설계가 있는지, 아니면 전체적인 설계가 객체지향적이지 못한 게 있는지 질문드립니다!

질문이 딱 정답을 내려주시기 힘든 부분이라 최송합니다 ㅠㅠ 

개발 진행 중 피드백을 받을 만한 방법이 없어서 이렇게나마 댓글로 부탁드립니다.

감사합니다!!

ps : 유튜브 토비의 봄에서 나오신 영상 2시간 가량 시간가는줄 모르고 재밌게 봤습니다!

답변 2

1

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

감사합니다! 쭉 진행하겠습니다!

1

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

안녕하세요. cjswoudddn님

팩토리 코드에 모아두신 부분은 잘 하셨어요^^

결국 어디 한부분은 구체적인 클래스들을 알고, 변경이 일어나야 하는데, 그것을 한 곳으로 모은 것이면 잘 설계한 것으로 볼 수 있습니다. 해당 부분을 Map<String, Protfolio> 정도로 변경하면 더 깔끔하게 될 것 같네요 ㅎㅎ

감사합니다.

cjswoudddn님의 프로필 이미지
cjswoudddn

작성한 질문수

질문하기