소멸 메서드의 호출 시점
335
2 asked
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)
[질문 내용]
SingletonBean.init
singletonBean1 = hello.core.scope.PrototypeTest$SingletonBean@54504ecd
singletonBean2 = hello.core.scope.PrototypeTest$SingletonBean@54504ecd
org.springframework.context.annotation.AnnotationConfigApplicationContext -
Closing SingletonBean.destroysingletonBeanFind()의 실행 결과입니다.
결과를 보면 ac.close() 로 인해 스프링 컨테이너가 종료된 뒤(네 번째 라인), 싱글톤 빈의 종료 메서드가 호출됩니다. 제가 이해한 바로는 싱글톤 빈의 소멸 메서드는 스프링 컨테이너가 종료되기 전에 호출된다고 알고 있습니다. 그런데 출력 순서를 보면 반대로 되어있어서 왜 그런건지 모르겠습니다
Answer 2
0
제 생각에는 스프링 컨테이너가 종료된 뒤 로그가 찍히는 것이 아니라 종료 작업이 시작될 때 찍히는 것 같습니다
그럼 자연스럽게 그 후에 종료 메서드 호출되는 게 이해가 되네요
혹시 틀린 정보라면 지적부탁드립니다
0
안녕하세요, 인프런 AI 인턴이에요. SingletonBean의 종료 메서드 호출 시점과 출력 순서에 대한 질문이시군요.
SingletonBean의 소멸 메서드는 스프링 컨테이너가 종료될 때 호출됩니다. 그런데, 로그 출력 순서가 예상과 반대로 되어 있어서 의아하시다는 말씀이신 것 같아요.
싱글톤 빈의 종료 메서드 호출 순서가 출력 순서와 다른 이유는 스프링의 빈 등록 방식 때문입니다. 스프링은 싱글톤 빈의 생성과 소멸을 담당하며, 종료 시점에 여러 빈의 소멸 메서드 호출을 담당하는데, 이때 빈 등록 순서에 따라 호출 순서가 결정되기 때문입니다.
싱글톤 빈의 생성과 소멸은 스프링 컨테이너 내에서 담당하기 때문에 개발자가 직접 제어할 수 있는 부분은 아닙니다. 따라서, 로그 출력 순서와 싱글톤 빈의 소멸 메서드 호출 순서가 일치하지 않을 수 있습니다.
출력 순서와 싱글톤 빈의 소멸 메서드 호출 순서를 일치시키고 싶다면, 일부러 종속성을 추가해 순서를 조정하거나, 다른 방식으로 처리해야 합니다. 하지만 이러한 조작은 스프링의 기본 동작을 변경시킬 수도 있기 때문에 신중하게 판단해야 합니다.
더 자세한 내용은 스프링 컨테이너의 동작 원리를 파악하고 싶다면, Spring Framework 공식 웹 사이트나 스프링 관련 서적을 참고하시면 될 것 같아요. 또한, 스프링 컨테이너의 동작과 빈의 라이프사이클에 대해서도 인프런의 관련 강의를 참고해보시면 도움이 될 것입니다. 감사합니다!
구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?
0
43
2
MemberService의 인터페이스를 왜 사용하는지 궁금합니다.
0
72
1
롬복 @Setter를 써야 하는 상황이 있는건가요?
0
87
1
빈 등록 메서드의 파라미터가 빈이 아니어도 되나요?
0
79
1
테스트 속도가 나중에 영향이 있을까요?
0
75
1
gradle 설정 안떠서 질문 남깁니다!
0
116
2
build.gradle로 프로젝트를 여는 이유
0
81
1
provider 사용하는 이유
0
82
1
다음 강의 뭘 들어야 할까요
0
123
2
프로토타입 빈, 직접 destroy 호출 안 할 경우
0
62
1
beanB
0
79
2
퀴즈다시풀기
0
63
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
115
2
생성자 자동주입 관련해서
0
60
1
생성자 직접 호출 vs 팩토리 메서드 패턴
0
91
2
Spring에서 SessionScope와 RequestScope는 함께 사용되나요?
1
62
1
12:25
0
74
2
appConfig.xml 오류
0
123
1

