MemberConroller에서 생성자를 통한 의존성 주입시 멤버 변수에 final 키워드를 사용하는 이유에 대한 질문입니다.
안녕하세요. 김영한 팀장님.
'컴포넌트 스캔과 자동 의존관계 설정' 강의 02:35 쯤
'MemberConroller' 클래스의 멤버변수로 'MemberService' 타입의 멤버변수를 선언할 때 final 키워드를 설정한 이유에 대한 질문입니다.
Java에서 final 키워드가 붙은 멤버변수는 쉽게 말해 '변할 수 없다.' 라는 의미를 가지게 됩니다.
저는 스프링에서 다루는 Bean은 '특별한 설정 설정(Scope)'이 없는 경우 싱글톤 형태로 스프링 컨테이너에 등록되어 상황에 따라 다른 클래스의 의존 주입 객체로 사용할 수 있는 것으로 이해하고 있습니다.
이러한 이유로 현재 MemberController에서는 Setter 메소드도 선언되지 않았으니 생성자를 통한 의존 주입 이후에는 MemberService 타입의 멤버변수가 변경될 가능성이 없다고 보아 final 키워드를 사용하지 않아도 되지 않을까? 하는 의문이 들었습니다.
그럼에도 불구하고 final 키워드를 사용한 이유가 궁금합니다!
미리 답변 감사드립니다.
답변 2
7
안녕하세요 Henu님. 간단히 예시를 만들어 보았습니다.
- Weapon 인터페이스는 attack이라는 int타입을 반환하는 메서드를 갖고 있습니다.
- Weapon 인터페이스를 구현한 Gun, Knife 클래스는 각각 100, 1을 반환합니다.
- final을 붙이지 않는 상태에서 생성자 주입으로 처음엔 Weapon에 Gun을 주입 받아서 출력합니다.(첫번째 그림)
- Gun 대신 Knife 인스턴스를 가리키도록 바꿉니다.(그림2)
- final 키워드를 붙이면 컴파일 에러가 발생합니다.(그림3)
- final 키워드를 사용함으로써 컴파일 타임에 체크가 가능한, 다른 주입에서는 불가능한 불변의 설계가 가능합니다.
감사합니다.

,
,
,
,
,

1
안녕하세요 Henu님.
궁금하신 부분인 그럼에도 불구하고 final 키워드를 사용한 이유가 궁금합니다!
에 대한 이유는 "불변으로 설계하기 위함"
private final~ 에서 final을 빼도 생성자 주입은 됩니다. 다만 final 키워드가 붙은 객체에 대한 생성자 주입은 객체를 생성할 때 딱 1번만 호출되므로 이후에 호출되는 일이 없고 불변하게 설계할 수 있습니다.
이에 대한 자세한 내용은 영한님의 다음 강의인 스프링 핵심 원리 에서 다루고 있습니다.
감사합니다.
0
위와 같은 이유로 생성자를 이용한 의존성 주입에는 final 키워드를
프로퍼티를 통한 의존성 주입에는 final 키워드를 사용하지 않는 이유에 대해서까지 이해되었습니다.
감사합니다.
인텔리제이 오류
0
49
1
..
0
113
2
Unused property.....
0
121
2
project JDK is misconfigured
0
165
2
외부 API의 ID 타입(String/UUID)과 내부 도메인의 ID 타입(Long)이 불일치할 때의 설계 정석
0
101
2
단위/통합 테스트 버전충돌 문제
0
102
2
❗️springboot 4.0.2 버전 aspectj dependency 설정❗️
0
255
1
왜 컨트롤러는 변한게 없는데 새로 만든 html 파일이 뜨나요?
0
124
2
윈도우 build test오류 질문
1
122
2
테스트 관련 공부에 대한 조언을 얻고 싶습니다
0
112
2
테스트 실행 시 에러 질문
0
313
1
name을 통한 비교와 객체를 통한 비교
0
81
1
빌드 후 libs 없음
1
148
1
윈도우 gradlew.bat 에러
0
186
1
@PostMapping("/members/new")가 동작하지 않습니다
0
98
1
java static class와 kotlin class
0
89
1
스프링 DB연결
0
145
1
소요 시간
0
96
2
ddl.sql에 빨간 밑줄
1
118
2
welcome page 에러
0
200
3
잘 모르겠습니다.
0
172
2
fail을 똑같이 쳤는데 오류가 발생해요
0
173
2
index.html Welcome page
0
137
1
프로젝트 gradle-groovy ?
0
403
1





