inflearn logo
강의

Course

Instructor

Spring Core Principles - Basic Edition

Member Domain Design

회원 도메인 인터페이스 개발

1

renekaltz5994

2 asked

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

[질문 내용]
회원 저장소를 갈아 끼울 수 있도록 설계할 때의 질문입니다.

예를들어 메모리 회원 저장소에서 회원 정보를 조회하기 위한 파라미터 값, db 회원 저장소에서 조회하기 위한 파라미터 값.. 등등 파라미터 값이 다른 경우에는 인터페이스 설계를 어떤 식으로 해야할까요?

실무에서는 외부 인터페이스 연동을 할 때나, db를 조회할 때나 파라미터 값이 그때그때 다 달랐던 것 같아서요.

 

그렇다면 저장소를 갈아 끼우더라도 각각 개발자가 넘겨줘야할 파라미터 값은 결국 변동될 수 밖에 없는건가요?

spring 객체지향

Answer 1

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. 김근오님.

회원 저장소를 포함하여 다양한 저장소에 따라 서로 다른 파라미터를 요구하는 상황에서 인터페이스를 설계하는 방식에 대해서는 많음 고민이 필요합니다. 파라미터 값이 저장소에 따라 달라질 수 있는 상황은 실무에서 빈번하게 발생하는 문제입니다.

이런 상황에서는 인터페이스를 설계할 때 유연성과 확장성을 고려해야 합니다.

  1. 통일된 인터페이스: 가장 기본적인 방법은 모든 저장소가 동일한 인터페이스를 구현하도록 하는 것입니다. 이렇게 하면 클라이언트 측에서 사용 방법이 통일되어 코드의 일관성을 유지할 수 있습니다. 만약 파라미터가 달라질 수 있다면 적절한 어댑터 패턴(또는 변환 층)을 사용하여 각각의 저장소에 맞는 요구 파라미터로 변환해 주는 방법이 있습니다.

  2. 옵션 객체 활용: 조회에 필요한 다양한 조건들을 포함할 수 있는 DTO(Data Transfer Object)나 Map과 같은 옵션 객체를 사용하는 방법도 있습니다. 이를 통해 다양한 파라미터 요구 사항을 하나의 구조체로 캡슐화하여 처리할 수 있습니다.

  3. 개별 구현부에서의 로직 전환: 동일한 인터페이스를 사용하되, 각 구현체에서 파라미터를 해석하고 처리하는 로직을 별도로 갖추는 방식입니다. 각 저장소가 자신에 맞게 요구된 파라미터를 해석하고 사용할 수 있도록 하는 것입니다.

저장소를 교체하더라도 인터페이스를 통해 상호작용을 할 수 있도록 설계하여 시스템 전반에 걸쳐 높은 유연성을 유지할 수 있습니다. 이로써 유지 보수의 용이성을 높일 수 있습니다.

이와 관련하여 회원 도메인 설계의 문제점 질문 등 유사한 질문에서 인터페이스와 구현체의 관계에 대한 내용을 확인하실 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

빈 스코프 개념의 중요성

0

27

1

SingletonService가 JVM이 뜰 때 생성되는게 맞나요?

0

72

2

섹션3. 11 회원객체 다이어그램

0

39

1

OCP, DIP과 @Qualifier 어노테이션에 대해서 질문합니다.

0

42

1

코드 자료

0

86

2

구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?

0

83

2

MemberService의 인터페이스를 왜 사용하는지 궁금합니다.

0

101

1

롬복 @Setter를 써야 하는 상황이 있는건가요?

0

105

1

빈 등록 메서드의 파라미터가 빈이 아니어도 되나요?

0

91

1

테스트 속도가 나중에 영향이 있을까요?

0

92

1

gradle 설정 안떠서 질문 남깁니다!

0

151

2

build.gradle로 프로젝트를 여는 이유

0

104

1

provider 사용하는 이유

0

102

1

다음 강의 뭘 들어야 할까요

0

141

2

프로토타입 빈, 직접 destroy 호출 안 할 경우

0

70

1

beanB

0

94

2

퀴즈다시풀기

0

78

1

Gradle로 바꿔도 오류가 똑같이 발생하네요 ㅠㅠ

0

105

2

"중복 등록과 충돌" 강의에서 강사님과 다른 에러가 발생합니다.

0

73

3

run 실행했는데 결과창이 이렇게 뜨네요 왜 그런건가요>

0

116

2

도메인의 정의?

0

64

1

ApplicationContext 질문입니다.

0

68

1

@Scope의 proxyMode를 사용할때 단위 테스트 방법

0

99

2

ai api 선정하기 관련 질문

0

141

2