반복되는 메소드를 Annotation을 사용하여 자동으로 작성해주는 라이브러리
일반적으로 VO, DTO, Model, Entity 등의 데이터 클래스에서 주로 사용됨
대표적으로 많이 사용되는 Annotation
- @Getter
- @Setter
- @NoArgsConstructor
- @AllArgsConstructor
- @Data
- @ToString
라이브러리 의존성 설정
dependencies {
compileOnly 'org.projectlombok:lombok:1.18.24'
annotationProcessor 'org.projectlombok:lombok:1.18.24'
testCompileOnly 'org.projectlombok:lombok:1.18.24'
testAnnotationProcessor 'org.projectlombok:lombok:1.18.24'
}
<dependencies>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
</dependencies>
해당 클래스에 선언되어 있는 필드를 기반으로 'getField', 'setField'와 같은 식으로 자동으로 메소드를 생성
@Getter
@Setter
public class MemberDTO {
private String name;
private String email;
private String organization;
}
다음을 자동으로 생성 ⬇︎
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
...
@NoArgsConstructor : 파라미터가 없는 생성자를 생성
@AllArgsConstructor : 모든 필드값을 파라미터로 갖는 생성자를 생성
@RequiredArgsConstructor : 필드값 중 final이나 @NotNull인 값을 갖는 생성자를 생성
@NoArgsConstructor
@AllArgsConstructor
@RequiredArgsConstructor
public class MemberDTO {
private String name;
private String email;
private String organization;
}
toString 메소드를 자동으로 생성해주는 기능
@ToString 어노테이션에 exclude 속성을 사용하여 특정 필드를 toString에서 제외시킬 수 있음
@ToString
public class MemberDTO {
private String name;
private String email;
private String organization;
}
@ToString(exclude = "email")
public class MemberDTO {
private String name;
private String email;
private String organization;
}
다음을 자동으로 생성 ⬇︎
@Override
public String toString() {
return "MemberDTO{" +
"name='" + name + '\'' +
", email='" + email + '\'' +
", organization='" + organization + '\'' +
'}';
}
equals, hasCode 메소드를 자동으로 생성
equals : 두 객체의 내용이 같은지 동등성(equality)를 비교하는 연산자
hashCode : 두 객체가 같은 객체인지 동일성(identity)를 비교하는 연산자
callSuper 속성을 통해 메소드 생성시 부모 클래스의 필드까지 고려할지 여부 설정 가능
- callSuper = ture ⇨ 부모 클래스 필드 값들도 동일한지 체크
해당 어노테이션을 사용하면, 앞서 나온 기능들을 한번에 추가해줌
- @Getter
- @Setter
- @RequiredArgsConstructor
- @ToString
- EqualsAndHashCode