Files
java-examples/docs/lombok.md

8.5 KiB

자바의 Lombok에 대해 설명하는 글을 작성하겠습니다. Lombok은 자바에서 반복적인 코드를 줄여주는 라이브러리로, 어노테이션을 활용해 Boilerplate 코드(예: Getter, Setter, 생성자 등)를 자동으로 생성해줍니다. 이를 통해 코드 가독성을 높이고 개발 생산성을 향상시킬 수 있습니다.

먼저, Lombok에서 제공하는 주요 어노테이션을 표 형식으로 정리한 뒤, 각 어노테이션에 대해 설명과 예시를 상세히 다루겠습니다.


Lombok 주요 어노테이션 표

어노테이션 설명
@Getter 필드에 대해 Getter 메서드를 자동 생성
@Setter 필드에 대해 Setter 메서드를 자동 생성
@ToString 클래스의 toString() 메서드를 자동 생성
@EqualsAndHashCode equals()와 hashCode() 메서드를 자동 생성
@NoArgsConstructor 매개변수가 없는 기본 생성자를 자동 생성
@AllArgsConstructor 모든 필드를 매개변수로 받는 생성자를 자동 생성
@RequiredArgsConstructor @NonNull이 붙은 필드나 final 필드만 매개변수로 받는 생성자를 생성
@Data @Getter, @Setter, @ToString, @EqualsAndHashCode, @RequiredArgsConstructor를 포함
@Builder 빌더 패턴을 구현한 코드를 자동 생성
@Slf4j SLF4J 로깅 프레임워크를 위한 Logger 객체를 자동 생성
@NonNull 필드나 매개변수가 null이 될 수 없음을 명시

각 어노테이션 상세 설명 및 예시

1. @Getter

  • 설명: 각 필드에 대해 Getter 메서드를 자동으로 생성합니다. 클래스의 모든 필드에 적용하려면 클래스 레벨에 붙일 수도 있습니다.
  • 예시:
import lombok.Getter;

@Getter
public class Person {
    private String name = "홍길동";
    private int age = 30;
}

public class Main {
    public static void main(String[] args) {
        Person person = new Person();
        System.out.println(person.getName()); // "홍길동" 출력
        System.out.println(person.getAge());  // 30 출력
    }
}

2. @Setter

  • 설명: 각 필드에 대해 Setter 메서드를 생성합니다. 클래스 레벨에서도 사용 가능하며, 특정 필드에만 적용하려면 필드 위에 붙입니다.
  • 예시:
import lombok.Setter;

@Setter
public class Person {
    private String name;
    private int age;
}

public class Main {
    public static void main(String[] args) {
        Person person = new Person();
        person.setName("김영희");
        person.setAge(25);
        System.out.println(person); // toString 없으므로 객체 참조 출력
    }
}

3. @ToString

  • 설명: 클래스의 필드를 기반으로 toString() 메서드를 생성합니다. 기본적으로 모든 필드를 포함하며, 제외하고 싶은 필드는 @ToString.Exclude를 사용합니다.
  • 예시:
import lombok.ToString;

@ToString
public class Person {
    private String name = "이철수";
    private int age = 40;
}

public class Main {
    public static void main(String[] args) {
        Person person = new Person();
        System.out.println(person); // Person(name=이철수, age=40) 출력
    }
}

4. @EqualsAndHashCode

  • 설명: equals()hashCode() 메서드를 필드 기반으로 생성합니다. 특정 필드를 제외하려면 @EqualsAndHashCode.Exclude를 사용합니다.
  • 예시:
import lombok.EqualsAndHashCode;

@EqualsAndHashCode
public class Person {
    private String name = "박민수";
    private int age = 28;
}

public class Main {
    public static void main(String[] args) {
        Person p1 = new Person();
        Person p2 = new Person();
        System.out.println(p1.equals(p2)); // true 출력
    }
}

5. @NoArgsConstructor

  • 설명: 매개변수가 없는 기본 생성자를 생성합니다. 주로 JPA나 프레임워크에서 요구될 때 사용됩니다.
  • 예시:
import lombok.NoArgsConstructor;

@NoArgsConstructor
public class Person {
    private String name = "최수진";
    private int age;
}

public class Main {
    public static void main(String[] args) {
        Person person = new Person(); // 기본 생성자 호출
        System.out.println(person.name); // "최수진" 출력
    }
}

6. @AllArgsConstructor

  • 설명: 모든 필드를 매개변수로 받는 생성자를 생성합니다.
  • 예시:
import lombok.AllArgsConstructor;

@AllArgsConstructor
public class Person {
    private String name;
    private int age;
}

public class Main {
    public static void main(String[] args) {
        Person person = new Person("김지영", 33);
        System.out.println(person.name); // "김지영" 출력
    }
}

7. @RequiredArgsConstructor

  • 설명: @NonNull이 붙은 필드나 final 필드만 포함한 생성자를 생성합니다.
  • 예시:
import lombok.RequiredArgsConstructor;
import lombok.NonNull;

@RequiredArgsConstructor
public class Person {
    @NonNull private String name;
    private int age; // 포함되지 않음
}

public class Main {
    public static void main(String[] args) {
        Person person = new Person("윤서진"); // name만 요구됨
        System.out.println(person.name); // "윤서진" 출력
    }
}

8. @Data

  • 설명: @Getter, @Setter, @ToString, @EqualsAndHashCode, @RequiredArgsConstructor를 모두 포함하는 편리한 어노테이션입니다.
  • 예시:
import lombok.Data;

@Data
public class Person {
    private String name;
    private int age;
}

public class Main {
    public static void main(String[] args) {
        Person person = new Person();
        person.setName("이정훈");
        person.setAge(29);
        System.out.println(person); // Person(name=이정훈, age=29) 출력
    }
}

9. @Builder

  • 설명: 빌더 패턴을 구현한 코드를 생성합니다. 객체를 유연하게 생성할 때 유용합니다.
  • 예시:
import lombok.Builder;

@Builder
public class Person {
    private String name;
    private int age;
}

public class Main {
    public static void main(String[] args) {
        Person person = Person.builder()
                .name("최영미")
                .age(35)
                .build();
        System.out.println(person.name); // "최영미" 출력
    }
}

10. @Slf4j

  • 설명: SLF4J 기반의 Logger 객체를 자동 생성합니다. 로깅 코드를 간소화할 수 있습니다.
  • 예시:
import lombok.extern.slf4j.Slf4j;

@Slf4j
public class Person {
    private String name = "김태양";

    public void printName() {
        log.info("Name: {}", name);
    }
}

public class Main {
    public static void main(String[] args) {
        Person person = new Person();
        person.printName(); // INFO: Name: 김태양 출력
    }
}

11. @NonNull

  • 설명: 필드나 매개변수가 null이 될 수 없음을 명시하며, null 체크 코드를 생성합니다. 주로 @RequiredArgsConstructor와 함께 사용됩니다.
  • 예시:
import lombok.NonNull;

public class Person {
    private final String name;

    public Person(@NonNull String name) {
        this.name = name; // null이면 예외 발생
    }
}

public class Main {
    public static void main(String[] args) {
        Person person = new Person("박준영"); // 정상 동작
        // Person nullPerson = new Person(null); // NullPointerException 발생
    }
}

결론

Lombok은 자바 개발에서 반복적인 코드를 줄이고, 가독성과 유지보수성을 높이는 데 큰 도움을 줍니다. 위 어노테이션들을 적절히 활용하면 생산성을 크게 향상시킬 수 있습니다. 단, 프로젝트에서 Lombok을 사용할 때는 팀원 모두가 이를 이해하고 IDE 설정(플러그인 설치 등)이 제대로 되어 있어야 원활한 협업이 가능합니다.

궁금한 점이 더 있다면 언제든 물어보세요!