inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 기본편

의존관계 주입과 Bean의 생명주기에 대해 질문드립니다!

171

Yebali

작성한 질문수 3

0

안녕하세요 강사님.

빈 의존관계 주입에 대한 강의를 들은 후, 주입 방식을 필드주입 -> 생성자 주입 으로 바꾸면서 발생한 오류에 대해 질문드립니다.

ServiceA와 ServiceB는 서로 순환 참조관계였습니다.

필드 주입을 사용한 코드는 아래와 같습니다.

@Service
public class ServiceA{

    @Autowired
    ServiceB B;
}
@Service
public class ServiceB{

    @Autowired
    ServiceA A;
}

위의 코드에서는 문제없이 동작하던 코드가

The dependencies of some of the beans in the application context form a cycle:

┌─────┐

|  serviceA defined in file [C:\Users\qazxs\Desktop\demo\build\classes\java\main\com\example\demo\ServiceA.class]

↑     ↓

|  serviceB defined in file [C:\Users\qazxs\Desktop\demo\build\classes\java\main\com\example\demo\ServiceB.class]

@Service
@RequiredArgsConstructor
public class ServiceA{

    private final ServiceB B;
}
@Service
@RequiredArgsConstructor
public class ServiceB{

    private final ServiceA A;
}

강의에서 Bean의 생명주기는 "스프링 컨테이너 생성 ->  스프링 빈 생성 -> 의존관계 주입 -> 초기화 콜백 -> ... " 의 순서로 진행된다고 배웠습니다.

필드 주입의 경우 생성자 없이 이미 생성된 빈들의 의존관계는 순환참조가 있더라도 주입이 가능하고,
생성자 주입의 경우 "스프링 빈 생성"단계(생성자)에서 순환 참조가 있을 경우 스프링 빈을 정상적으로 생성하지 못해 오류가 발생한다고 히해해도 될까요?

늘 좋은 강의 감사합니다. 강의를 들을 수록 수정할 코드가 보이는게 보람이 있습니다 ㅎㅎ

Bean생명주기 순환참조 oop spring

답변 1

1

김영한

안녕하세요. Yebali님

의존관계 주입 순서는 사실은 더 복잡합니다. 특히 생성자 주입의 경우에는 생성자를 호출해야 객체를 생성할 수 있기 때문에, 해당 객체를 생성하기 위해 필요한 부분을 다 찾아서 먼저 생성해주어야 합니다. 반면에 필드 주입의 경우에는 객체를 먼저 생성해두고, 그 다음에 연관된 객체를 생성해서 불러와도 되지요. 이런 차이점 때문에 생성자 주입에서는 오류가 발생합니다.

그런데 가장 중요한 사실은 이런 양방향 의존관계는 가급적 만들지 않아야 한다는 점입니다!

A -> B, B -> A

다음과 같이 변경하는 방안을 고민해보세요^^

A -> C

B -> C

감사합니다.

0

Yebali

설명 감사합니다! ㅎㅎ

양뱡향 의존관계도 제거하였습니다 ㅎㅎ

코드 자료

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

103

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