빈 출력하기
모든 빈 출력하기
@Test
@DisplayName("모든 빈 출력하기")
void findAllBean() {
String[] beanDefinitionNames = ac.getBeanDefinitionNames();
for (String beanDefinitionName : beanDefinitionNames) {
Object bean = ac.getBean(beanDefinitionName);
System.out.println("name=" + beanDefinitionName + " object=" + bean);
}
}
스프링에 등록된 모든 빈 정보를 출력할 수 있다.
애플리케이션 빈 출력하기
@Test
@DisplayName("모든 빈 출력하기")
void findAllBean() {
String[] beanDefinitionNames = ac.getBeanDefinitionNames();
for (String beanDefinitionName : beanDefinitionNames) {
BeanDefinition beanDefinition = ac.getBeanDefinition(beanDefinitionName);
if (beanDefinition.getRole() == BeanDefinition.ROLE_APPLICATION) {
Object bean = ac.getBean(beanDefinitionName);
System.out.println("name=" + beanDefinitionName + " object=" + bean);
}
}
}
스프링이 내부에서 사용하는 빈은 제외하고, 내가 등록한 빈만 출력할 수 있다.
`ROLE_APPLICATION` : 일반적으로 사용자가 정의한 빈
`ROLE_INFRASTRUCTURE` : 스프링이 내부에서 사용하는 빈
타입, 이름으로 빈 조회하기
`ac.getBean(빈 이름, 타입)` 또는 `ac.getBean(타입)` 으로 조회할 수 있다.
>참고<
- 조회 대상 스프링 빈이 없으면 `NoSuchBeanDefinitionException`이 발생한다.
- 타입으로 조회 시 같은 타입이 여러 개라면 `NoUniqueBeanDefinitionException`이 발생한다.
@Test
@DisplayName("빈 이름으로 조회")
void findBeanByName() {
MemberService memberService = ac.getBean("memberService", MemberService.class);
assertThat(memberService).isInstanceOf(MemberServiceImpl.class);
}
@Test
@DisplayName("이름 없이 타입만으로 조회")
void findBeanByName() {
MemberService memberService = ac.getBean(MemberService.class);
assertThat(memberService).isInstanceOf(MemberServiceImpl.class);
}
이때, 구체 타입으로 조회할 수도 있다.
(구체 타입으로 조회하는 것은 유연성이 떨어지기 때문에 지양해야 한다.)
@Test
@DisplayName("빈 이름으로 조회")
void findBeanByName() {
MemberService memberService = ac.getBean("memberService", MemberServiceImpl.class);
assertThat(memberService).isInstanceOf(MemberServiceImpl.class);
}
특정 타입을 모두 조회할 수도 있다.
MemberRepository 타입을 가진 빈이 2개라고 가정하자.
@Test
@DisplayName("특정 타입을 모두 조회하기")
void findAllBeanByType() {
Map<String, MemberRepository> beansOfType = ac.getBeansOfType(MemberRepository.class);
for (String key : beansOfType.keySet()) {
System.out.println("key = " + key + " value = " + beansOfType.get(key));
}
assertThat(beansOfType.size()).isEqualTo(2);
}
상속 관계에서 빈 조회하기
부모 타입으로 조회하면, 자식 타입도 함께 조회된다.
>참고<
- 타입으로 조회 시 자식이 둘 이상이라면 `NoUniqueBeanDefinitionException`이 발생한다.
DiscountPolicy 의 자식 타입의 빈이 2개라고 가정하자.
@Test
@DisplayName("부모 타입으로 모두 조회하기")
void findAllBeanByParentType() {
Map<String, DiscountPolicy> beansOfType = ac.getBeansOfType(DiscountPolicy.class);
for (String key : beansOfType.keySet()) {
System.out.println("key = " + key + " value=" + beansOfType.get(key));
}
assertThat(beansOfType.size()).isEqualTo(2);
}
빈 설정 메타 정보 BeanDefinition
@Bean, <bean> 각각의 메타 정보가 추상화되어 BeanDefinition 이 생성되며,
이 메타 정보를 기반으로 스프링 컨테이너가 스프링 빈을 생성한다.
BeanDefinition 은 아래의 정보를 담고 있다.
`BeanClassName` : 생성할 빈의 클래스 명(자바 설정처럼 팩토리 역할의 빈을 사용하면 없음)
`factoryBeanName` : 팩토리 역할의 빈을 사용할 경우 이름, 예) appConfig
`factoryMethodName` : 빈을 생성할 팩토리 메서드 지정, 예) memberService
`Scope` : 싱글톤(기본값)
`lazyInit` : 스프링 컨테이너를 생성할 때 빈을 생성하는 것이 아니라, 실제 빈을 사용할 때까지 최대한 생성을 지연 처리 하는지 여부
`InitMethodName` : 빈을 생성하고, 의존관계를 적용한 뒤에 호출되는 초기화 메서드 명
`DestroyMethodName` : 빈의 생명주기가 끝나서 제거하기 직전에 호출되는 메서드 명
`Constructor arguments, Properties` : 의존관계 주입에서 사용한다. (자바 설정처럼 팩토리 역할의 빈을 사용하면 없음)
출처 | 스프링 핵심 원리 - 기본(김영한) - 인프런
'💠프로그래밍 언어 > Java' 카테고리의 다른 글
[Spring] 롬복 라이브러리의 편리한 기능들 (0) | 2025.02.26 |
---|---|
[Spring] 스프링 컨테이너 (애노테이션 기반, XML 기반) (1) | 2025.02.26 |
[Spring] AOP 는 무엇일까 ?? (0) | 2024.12.30 |
[Spring] 순수 JDBC → JdbcTemplate → JPA → 스프링 데이터 JPA (0) | 2024.12.30 |
[Spring] H2 데이터베이스 설치, 스프링 통합 테스트 (0) | 2024.12.30 |