개발을 해보면, 대부분이 다 불변이고, 그래서 다음과 같이 생성자에 final 키워드를 사용하게 됩니다.
그래서 생성자도 만들어야 하고, 주입 받은 값을 대입하는 코드도 만들어야 합니다.
기본 코드
@Component
public class OrderServiceImpl implements OrderService {
private final MemberRepository memberRepository;
private final DiscountPolicy discountPolicy;
public OrderServiceImpl(MemberRepository memberRepository, DiscountPolicy discountPolicy) {
this.memberRepository = memberRepository;
this.discountPolicy = discountPolicy;
}
}
- 롬복 라이브러리가 제공하는
@RequiredArgsConstructor
기능을 사용하면 final이 붙은 필드를 모아서 생성자를 자동으로 만들어줍니다. (코드에는 보이지 않지만 실제 호출이 가능합니다.)
최종 결과 코드
@Component
@RequiredArgsConstructor
public class OrderServiceImpl implements OrderService {
private final MemberRepository memberRepository;
private final DiscountPolicy discountPolicy;
...
}
롬복이 자바의 애노테이션 프로세서라는 기능을 이용해서 컴파일 시점에 생성자 코드를 자동으로 생성해줍니다. 실제 class
를 열어보면 다음 코드가 추가되어 있는 것을 확인할 수 있습니다.
public OrderServiceImpl(MemberRepository memberRepository, DiscountPolicy discountPolicy) {
this.memberRepository = memberRepository;
this.discountPolicy = discountPolicy;
}
정리
최근에는 생성자를 딱 1개 두고, @Autowired
를 생략하는 방법을 주로 사용합니다. 여기에 Lombok 라이브러리의 @RequiredArgsConstructor
를 함께 사용하면 기능은 다 제공하면서, 코드는 깔끔하게 사용할 수 있습니다.
롬복 라이브러리 적용 방법
build.gradle
에 라이브러리 및 환경 추가
plugins {
id 'org.springframework.boot' version '2.5.4'
id 'io.spring.dependency-management' version '1.0.11.RELEASE'
id 'java'
}
group = 'hello'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = '11'
//lombok 설정 추가 시작
configurations {
compileOnly {
extendsFrom annotationProcessor
}
}
//lombok 설정 추가 끝
repositories {
mavenCentral()
}
dependencies {
implementation 'org.springframework.boot:spring-boot-starter'
//lombok 라이브러리 추가 시작
compileOnly 'org.projectlombok:lombok'
annotationProcessor 'org.projectlombok:lombok'
testCompileOnly 'org.projectlombok:lombok'
testAnnotationProcessor 'org.projectlombok:lombok'
//lombok 라이브러리 추가 끝
testImplementation 'org.springframework.boot:spring-boot-starter-test'
}
test {
useJUnitPlatform()
}
- Preferences(윈도우 File => Settings) -> plugin -> lombok 검색 설치 실행 (재시작)
- Preferences -> Annotation Processors 검색 -> Enable annotation processing 체크 (재시작)
- 임의의 테스트 클래스를 만들고 @Getter, @Setter 확인
참조
'Spring' 카테고리의 다른 글
[스프링 핵심 원리 - 기본편] @Autowired 필드 명, @Qualifier, @Primary (0) | 2021.09.20 |
---|---|
[스프링 핵심 원리 - 기본편] 조회 빈이 2개 이상 - 문제 (0) | 2021.09.20 |
[스프링 핵심 원리 - 기본편] 생성자 주입을 선택해라! (0) | 2021.09.20 |
[스프링 핵심 원리 - 기본편] 옵션 처리 (0) | 2021.09.20 |
[스프링 핵심 원리 - 기본편] 다양한 의존관계 주입 방법 (0) | 2021.09.19 |
댓글