작성
·
410
·
수정됨
0
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
[질문 내용]
여기에 질문 내용을 남겨주세요.
제 MemberServiceImpl 생성자는 다음과 같습니다.
그리고, MemoryMemberRepository 클래스에 임의로 생성자를 추가해주었습니다.
로그에 bean 생성 순서가 어떻게 되나 찍기 위해 임의로 만들어준 것입니다.
출력되는 로그는 다음과 같습니다.
22:05:11.598 [main] DEBUG org.springframework.beans.factory.support.DefaultListableBeanFactory - Creating shared instance of singleton bean 'memberServiceImpl'
22:05:11.614 [main] DEBUG org.springframework.beans.factory.support.DefaultListableBeanFactory - Creating shared instance of singleton bean 'memoryMemberRepository'
1
22:05:11.629 [main] DEBUG org.springframework.beans.factory.support.DefaultListableBeanFactory - Autowiring by type from bean name 'memberServiceImpl' via constructor to bean named 'memoryMemberRepository'
memberRepository = hello.core.member.MemoryMemberRepository@1a45193b
제가 처음에 생각했던 것은, MemberServiceImpl 객체를 생성하여 bean으로 등록하려고 하는 시점에, 생성자를 통해 객체를 생성하는 과정을 거칠텐데, 이 때 생성자에 필요한 인자인 MemberRepository 객체가 아직 bean으로 등록되어 있지 않은 상황이라, 자동 주입이 이루어지지 않아 먼저 MemberRepository 객체부터 생성하고 bean으로 등록한 이후에, 마저 MemberServiceImpl 객체 생성을 마치고 bean으로 등록하는 과정으로 생각했습니다.
그런데, 로그를 찍어보니까, 일단 먼저 memberServiceImpl이 bean으로 등록되고, 그 다음 memoryMemberRepository도 bean으로 등록된 다음에, memoryMemberRepository가 생성자를 통해 (1이 로그에 출력된 것으로 확인 가능) 객체로 생성되고(?) 그 다음 @Autowired를 통해 의존관계 주입이 되고, memberServiceImpl 생성자가 실행되는 것을 확인할 수 있습니다(memberRepository = ~ 구문이 로그에 출력된 것으로 확인 가능).
memberServiceImpl의 생성자가 실행되기도 전에 memberServiceImpl이 bean으로 등록되는 과정이 이해가 가지 않습니다. (Creating shared instance of singleton bean 'memberServiceImpl'). memoryMemberRepository도 마찬가지입니다.
생성자가 실행되기도 전에 Creating shared instance of singleton bean 문구가 출력되는 이유를 모르겠습니다.
bean으로 생성(등록)되려면, 생성자를 통해 실행되는 것 아닌가요? 왜 bean으로 먼저 생성되고, 그 이후에, 자동관계 주입이 된 후에 생성자가 실행되는 것인지 질문 드립니다.
답변 3
1
안녕하세요. 강민석님, 공식 서포터즈 David입니다.
Creating shared instance of singleton bean 로그는 빈 생성 과정 시작부분에 위치하고 있습니다. 따라서, 생성 이전에 로그가 찍힐 수 있습니다. 이와 관련코드는 아래 링크를 참고해 주세요.
빈 생성 뿐만 아니라 의존관계 주입의 경우도 질문자 분께서 생각하는 시점과 로그의 시점이 다를 수 있으므로 코드 레벨로 디버깅 해보셔야 정확한 빈 생성, 의존관계 주입 시점을 확인할 수 있습니다.
감사합니다.
0
안녕하세요. 강민석님
"Creating shared instance of singleton bean 'memberServiceImpl'"의 뜻은 'memberServiceImpl' 싱글톤 빈의 공유 인스턴스를 생성하는 중이라는 뜻입니다. 다 만들어서 완성된 것이 아니라, 생성하는 과정 중임을 나타냅니다.
따라서 생각하신 순서가 맞습니다 :)
감사합니다.
0
안녕하세요, 인프런 AI 인턴이에요.
@Autowired 어노테이션을 사용한 생성자 주입 관련하여 질문이 있으신 것 같네요. 꼭 도움을 드릴게요.
위의 내용을 따로 확인할 필요는 없을 것 같으니, 바로 질문 내용을 알려주시면 됩니다. 제가 최대한 도움을 드릴게요.