반응형
정적 팩터리 메서드가 생성자 보다 좋은 이유
1. 이름을 가질 수 있다. (직관적으로 해당 메서드의 역할을 알 수 있다.)
- 메서드의 이름을 직관적으로 표현 ex) public int SumNum(int a, int b)
2. 호출될 때마다 인스턴스를 새로 생성하지 않아도 된다. (싱글톤)
- 정적 메서드와 캐싱 구조를 함께 쓰면 매번 새로운 객체를 생성할 필요가 없다. ex) Boolean.valueof(Bolean)
3. 반환타입의 하위 타입 객체를 반환할 수 있는 능력이 있다.
- 반환 객체의 클래스를 자유롭게 선택 할 수 있다. (유연성 확보)
4. 입력 매개변수에 따라 매번 다른 클래스의 객체를 반환할 수 있다.
- 반환 타입의 하위 타입이면 어떤 클래스의 객체를 반환하든 상관없다.
5. 정적 팩터리 메서드를 작성하는 시점에는 반환할 객체의 클래스가 존재하지 않아도 된다.
- 유연한 서비스 제공자 프레임워크를 만드는 근간이 된다. ex) 서비스 접근 API
정적 팩터리 메서드와 public 생성자의 쓰임새, 장단점 파악하기
무작정 public 생성자를 제공하던 습관을 고치기
반응형
'책 공부 > Effective Java' 카테고리의 다른 글
Effective Java Item 6. 불필요한 객체 생성을 피하라 (0) | 2022.05.03 |
---|---|
Effective Java Item 5. 자원을 직접 명시하지 말고 의존 객체 주입을 사용하라 (0) | 2022.05.01 |
Effective Java Item 4. 인스턴스화를 막으려거든 private 생성자를 사용하라 (0) | 2022.04.28 |
Effective Java Item 3. Private 생성자나 열거타입으로 싱글톤을 보장하라 (0) | 2022.04.26 |
Effective Java Item 2. 생성자에 매개 변수가 많다면 빌더를 고려하라 (0) | 2022.04.24 |