Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 |
Tags
- 알고리즘
- 멀티 쓰레드
- 인프런
- 중급자바
- 스레드 제어와 생명 주기
- 오케스트레이션
- Docker
- container
- java
- 도커 엔진
- 동시성
- 리스트
- 자바
- contatiner
- 시작하세요 도커 & 쿠버네티스
- 자료구조
- Collection
- 컨테이너
- 쓰레드
- Thread
- 시작하세요! 도커 & 쿠버네티스
- 쿠버네티스
- 김영한
- 실전 자바 고급 1편
- 도커
- LIST
- 스레드
- Kubernetes
- 제네릭스
- 실전 자바 중급 2편
Archives
- Today
- Total
쌩로그
롬복 라이브러리 @Value, @NonNull 본문
반응형
롬복 라이브러리의 @Value(참고로 GPT가 알려줌)
- 모든 필드가
final
이 되고, 불변- 선언된 모든 필드가 자동으로
final
이 되어 불변 객체로 작동합니다.
- 선언된 모든 필드가 자동으로
- 모든 필드에 대해
private final
생성- 기본 접근 제어자는
private
이고, 필드는final
로 선언됩니다.
- 기본 접근 제어자는
- 생성자 자동 생성:
- 모든
final
필드를 포함하는 생성자를 자동으로 생성합니다.
- 모든
- Getter 메서드 생성
- 모든 필드에 대해 Getter 메서드를 자동으로 생성합니다.
equals()
,hashCode()
,toString()
자동 생성- 모든 필드를 기반으로
equals()
,hashCode()
및toString()
메서드를 생성합니다.
- 모든 필드를 기반으로
- Setter 메서드 없음
- 불변성을 유지하기 위해 Setter 메서드는 생성되지 않습니다.
+ 참고 하나 더
@Value
는 클래스 전체를 불변으로 설계할 때 유용하며, 유연한 필드 접근이나 수정이 필요한 경우에는 적합하지 않을 수 있습니다.- Java Record를 사용하는 경우
@Value
와 비슷한 역할을 수행할 수 있습니다(Java 14+).
롬복 라이브러리의 @NonNull
- 각 필드마다
null
을 허용하지 않도록@NonNull
애너테이션들이 붙어있었다. - 모든 필드에 붙어있기 때문에 클래스 레벨에 선언하면 모든 필드에 적요되지 않을까 했지만, 클래스 레벨에 붙이면 아무 효과가 없고, 모든 필드에 대해 하나씩 명시적으로 추가해야 한다.
728x90
Comments