특정 하위 타입으로 조회할 때 궁금한 점 있습니다.
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)
[질문 내용]
아래 코드의 findBeanBySubType()에서
RateDiscountPolicy bean = ac.getBean(RateDiscountPolicy.class);
이 부분을 보면 RateDiscountPolicy 타입으로 조회한다는 뜻인데
TestConfig를 보면 rateDiscountPolicy는 리턴할 때 RateDiscountPolicy를 리턴하지만 메서드 시그니처에 있는 리턴 타입 자체는 DiscountPolicy이잖아요?
RateDiscountPolicy bean = ac.getBean(RateDiscountPolicy.class);를 실행한 이후 동작 과정이 궁금합니다.
DiscountPolicy 타입인 빈들을 먼저 찾고 그것들이 여러 개일 때 RateDiscountPolicy를 찾는지, 아니면 바로 처음부터 RateDiscountPolicy인지 FixDiscountPolicy인지 구분할 수 있는지 궁금합니다.
@Test
@DisplayName("특정 하위 타입으로 조회")
public void findBeanBySubType() {
RateDiscountPolicy bean = ac.getBean(RateDiscountPolicy.class);
assertThat(bean).isInstanceOf(RateDiscountPolicy.class);
}
@Configuration
static class TestConfig {
@Bean
public DiscountPolicy rateDiscountPolicy() {
return new RateDiscountPolicy();
}
@Bean
public DiscountPolicy FixDiscountPolicy() {
return new FixDiscountPolicy();
}
}
}
답변 2
2
안녕하세요.
빈을 생성하고 구성하고 관리하는 빈 팩토리의 기본 구현체인
DefaultListableBeanFactory클래스를 살펴보니
다음과 같이 모든 빈을 순회하면서 일치하는 타입의 빈들을 찾고 있다는 것을 알 수 있었습니다.
private String[] doGetBeanNamesForType(ResolvableType type, boolean includeNonSingletons, boolean allowEagerInit) {
List<String> result = new ArrayList<>();
// Check all bean definitions.
for (String beanName : this.beanDefinitionNames) {
...
boolean matchFound = false;
...
matchFound = isTypeMatch(beanName, type, allowFactoryBeanInit);
...
if (matchFound) {
result.add(beanName);
}
}
// Check manually registered singletons too.
for (String beanName : this.manualSingletonNames) {
...
if ((includeNonSingletons || isSingleton(beanName)) && isTypeMatch(beanName, type)) {
result.add(beanName);
}
...
}
return StringUtils.toStringArray(result);
}
1. @Configuration의 @Bean이 달린 메소드의 리턴 값이 상위 객체라고 하더라도, 생성된 객체의 타입 정보는 하위 객체를 나타내고 있습니다.
모든 빈을 순회하며 찾으려는 객체의 타입 정보와 일치하는지 비교하고 있기 때문에 한번의 순회로 하위 객체를 찾습니다.
0
안녕하세요, 인프런 AI 인턴이에요.
findBeanBySubType() 메소드에서 RateDiscountPolicy 타입으로 조회하고 있습니다. 메서드 시그니처에 있는 리턴 타입이 DiscountPolicy인 이유는 스프링 컨테이너가 해당 타입의 빈을 조회해주기 때문입니다.
ac.getBean(RateDiscountPolicy.class)를 실행하면, RateDiscountPolicy 타입인 빈들을 먼저 찾고, 그 중에서 여러 개일 경우 첫 번째 RateDiscountPolicy 빈을 생성하고 리턴합니다. 따라서, findBeanBySubType() 메소드를 실행하면 RateDiscountPolicy 타입의 빈이 리턴될 겁니다.
그리고 assertThat(bean).isInstanceOf(RateDiscountPolicy.class);는 bean이 RateDiscountPolicy 타입인지 검증하는 코드입니다. 이 코드를 실행하면 bean이 RateDiscountPolicy 타입인지 확인하게 됩니다.
즉, findBeanBySubType() 메소드는 RateDiscountPolicy 타입의 빈을 찾아 리턴하며, assertThat 코드를 통해 해당 빈이 정상적으로 RateDiscountPolicy 타입인지 검증하는 것입니다.
요청하신 답변이 도움이 되셨나요? 추가로 궁금한 점이 있으면 언제든지 물어보세요. 감사합니다.
코드 자료
0
30
2
구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?
0
51
2
MemberService의 인터페이스를 왜 사용하는지 궁금합니다.
0
75
1
롬복 @Setter를 써야 하는 상황이 있는건가요?
0
89
1
빈 등록 메서드의 파라미터가 빈이 아니어도 되나요?
0
81
1
테스트 속도가 나중에 영향이 있을까요?
0
77
1
gradle 설정 안떠서 질문 남깁니다!
0
121
2
build.gradle로 프로젝트를 여는 이유
0
85
1
provider 사용하는 이유
0
88
1
다음 강의 뭘 들어야 할까요
0
126
2
프로토타입 빈, 직접 destroy 호출 안 할 경우
0
64
1
beanB
0
82
2
퀴즈다시풀기
0
67
1
Gradle로 바꿔도 오류가 똑같이 발생하네요 ㅠㅠ
0
92
2
"중복 등록과 충돌" 강의에서 강사님과 다른 에러가 발생합니다.
0
66
3
run 실행했는데 결과창이 이렇게 뜨네요 왜 그런건가요>
0
106
2
도메인의 정의?
0
59
1
ApplicationContext 질문입니다.
0
63
1
@Scope의 proxyMode를 사용할때 단위 테스트 방법
0
88
2
ai api 선정하기 관련 질문
0
118
2
생성자 자동주입 관련해서
0
65
1
생성자 직접 호출 vs 팩토리 메서드 패턴
0
96
2
Spring에서 SessionScope와 RequestScope는 함께 사용되나요?
1
65
1
12:25
0
77
2





