inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 기본편

@Autowired 필드 명, @Qualifier, @Primary

Qualifier, 빈 이름 지정 등 OCP 위반

550

황영빈

작성한 질문수 3

0

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

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

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

[질문 내용]

강의를 듣다보니 궁금한 점이 생겨서 질문 남깁니다.

Interface에 대한 구현체가 여러개인 경우, 어떤 빈을 주입할지 결정하기 위해 @Qualifier를 이용하거나 빈 이름을 지정하는 방법등을 사용한다고 강의에 나오는데요.

이것을 보다보니 구현체를 바꾸려면 결국 사용하는 서비스 layer에서 관련 코드 (구현체를 바꾸는)를 수정해야 하는 거 같은데 이러면 OCP를 위반하게 되는 거 같아서요.


OCP 위반을 막으려면 AppConfig를 도입했을 때처럼 구현체를 설정하는 역할을 분리하고 수동 빈 등록으로 가야하는거 아닌가라는 생각이 들었는데 보통 실무에서는 어떻게 처리하는게 맞을까요??

구현체를 바꾸는 코드 변경정도는 tradeoff로 감수하는 편인가요 역할 분리하는 편인가요??

spring 객체지향 ocp

답변 2

0

David

안녕하세요. 황영빈님, 공식 서포터즈 David입니다.

트레이드오프로 생각합니다.

아래 글 답변을 참고해 주세요:)

https://www.inflearn.com/questions/160058

감사합니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴이에요.

OCP(Open-Closed Principle)는 소프트웨어 개발의 원칙 중 하나입니다. OCP는 수정에는 닫혀 있고 확장에는 열려있어야 한다는 의미를 가지고 있습니다. 즉, 기존의 코드를 수정하지 않고도 새로운 기능을 추가할 수 있어야 합니다.

구현체를 변경하려면 사용하는 서비스 layer의 관련 코드를 수정해야 한다는 것은 맞습니다. 하지만 OCP를 위반하지 않으려면 구현체를 변경하는 부분을 인터페이스로 추상화하여 외부에서 구현체를 주입받도록 설계해야 합니다.

@Qualifier나 빈 이름을 지정하는 방법은 구현체를 주입받을 때 어떤 빈을 사용할지 결정하기 위한 방법입니다. 이를 통해 구현체를 변경하더라도 해당 빈의 이름이나 Qualifier만 수정하면 코드 변경을 최소화할 수 있습니다. 이렇게 인터페이스를 사용하여 외부에서 구현체를 주입받는 방식은 OCP를 준수하는 방법 중 하나입니다.

따라서, OCP를 위반하지 않으면서 구현체를 변경하려면 인터페이스를 사용하여 구현체를 주입받도록 설계해야 합니다. 이렇게 하면 구현체를 바꿀 때 관련된 코드 변경을 최소화할 수 있습니다.

더 자세한 내용이 필요하시면 구체적인 코드나 상황을 알려주시면 더 도움을 드릴 수 있을 것 같아요. 좋은 공부 되세요!

코드 자료

0

21

2

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

0

50

2

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

0

72

1

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

0

87

1

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

0

79

1

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

0

75

1

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

0

118

2

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

0

82

1

provider 사용하는 이유

0

86

1

다음 강의 뭘 들어야 할까요

0

123

2

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

0

62

1

beanB

0

80

2

퀴즈다시풀기

0

64

1

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

0

90

2

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

0

63

3

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

0

102

2

도메인의 정의?

0

57

1

ApplicationContext 질문입니다.

0

60

1

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

0

86

2

ai api 선정하기 관련 질문

0

116

2

생성자 자동주입 관련해서

0

62

1

생성자 직접 호출 vs 팩토리 메서드 패턴

0

94

2

Spring에서 SessionScope와 RequestScope는 함께 사용되나요?

1

63

1

12:25

0

75

2