다형성 관련해서 질문 드립니다
MemberRepository를 인터페이스, MemoryMemberRepository를 구현 클래스로 사용하다가 DB를 사용하기로 결정이 나면 DbMemberRepository를 새로 만들어서 구현 클래스를 대체하는 방식의 이점은 어느 정도는 이해를 했습니다.
그런데 이 방법 대신 MemberRepository를 메모리를 사용하는 리포지토리 구현체로 사용하다가 나중에 MemberRepository 자체를 DB를 사용하는 리포지토리 구현체로 바꿔주면 안될까요?
적절한 반례가 떠오르지를 않아서 질문드립니다.
좋은 강의 항상 감사합니다.
답변 1
3
안녕하세요. 이승재님, 공식 서포터즈 y2gcoder입니다.
다형성의 이점에 대한 것을 이해하셨다고 말씀하셨기 때문에 반례에 대해서 말씀드려보겠습니다.
예를 들어 메모리를 사용하는 리포지토리 구현체를 JPA를 사용하는 리포지토리 구현체로 변경하게 되었다고 하면,
같은 결과를 도출하는 메서드명이 다를 경우에 변경이 필요합니다 findOne(Long id)로 메모리 구현체에서 사용하고 있었다면 jpa에서는 findById(Long id)를 사용하는데 당연히 이를 사용한 모든 부분에서 변경이 필요합니다.
영한님께서 기본편에서 보여주신 MemoryMemberRepository는 기본적으로 메서드 네이밍이나 작동 방식들이 후에 사용할 DB 구현체에 맞춰 만들어졌기 때문에 교체할 부분이 많지 않아 보일 수 있습니다.
대신 인터페이스라는 설계도를 그려놓고 그에 맞춰 구현체를 만들면 최소한 의존성 주입 조차 변경할 필요 없이 그냥 손쉽게 리포지토리를 변경할 수 있게 됩니다.
감사합니다.
섹션3. 11 회원객체 다이어그램
0
34
1
OCP, DIP과 @Qualifier 어노테이션에 대해서 질문합니다.
0
35
1
코드 자료
0
72
2
구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?
0
76
2
MemberService의 인터페이스를 왜 사용하는지 궁금합니다.
0
91
1
롬복 @Setter를 써야 하는 상황이 있는건가요?
0
97
1
빈 등록 메서드의 파라미터가 빈이 아니어도 되나요?
0
84
1
테스트 속도가 나중에 영향이 있을까요?
0
87
1
gradle 설정 안떠서 질문 남깁니다!
0
130
2
build.gradle로 프로젝트를 여는 이유
0
96
1
provider 사용하는 이유
0
96
1
다음 강의 뭘 들어야 할까요
0
132
2
프로토타입 빈, 직접 destroy 호출 안 할 경우
0
69
1
beanB
0
88
2
퀴즈다시풀기
0
70
1
Gradle로 바꿔도 오류가 똑같이 발생하네요 ㅠㅠ
0
99
2
"중복 등록과 충돌" 강의에서 강사님과 다른 에러가 발생합니다.
0
68
3
run 실행했는데 결과창이 이렇게 뜨네요 왜 그런건가요>
0
108
2
도메인의 정의?
0
60
1
ApplicationContext 질문입니다.
0
67
1
@Scope의 proxyMode를 사용할때 단위 테스트 방법
0
97
2
ai api 선정하기 관련 질문
0
129
2
생성자 자동주입 관련해서
0
68
1
생성자 직접 호출 vs 팩토리 메서드 패턴
0
100
2





