생성자 대신 정적 팩토리 메서드를 고려하라
- 대부분의 상황에서는 생성자가 유효하다
- 정적 팩토리 메서드가 유효한 상황이 있다
- 생성자는 이름을 표현할 수 없다.
정적 팩토리 메서드를 사용하는 방법
public static primeOrder(Product product){
Order order = new Order();
order.prime = true;
order.product = product;
return order;
}
public static urgentOrder(Product product, boolean prime){
Order order = new Order();
order.urgent = true;
order.product = product;
return order;
}
정적 팩토리 메서드의 장점은?
- 이름을 가질 수 있다.
public static primeOrder(Product prodcut){..}
public static urgentOrder(Product product){..}
- 호출될 때마다 인스턴트를 새로 생성하지 않아도 된다.
- 객체 생성을 외부가 아니라 자신이 컨트롤 한다는 의미 ex) Boolean.valueOf(boolean);
- 변환 타입의 하위 타입 객체를 반환할 수 있는 능력이 있다.
- interface타입 사용 가능
- 클래스를 선언해놓고 그 클래스의 하위 타입 사용 가능
- 입력 매개변수에 따라 매번 다른 클래스의 객체를 반환할 수 있다.
public static HelloService of(String lang){
if("ko".equals(lang){}
else {..}
}
- 정적 팩토리 메서드를 작성하는 시점에는 반환할 객체의 클래스가 존재하지 않아도 된다.
정적 팩토리 메서드의 단점은?
- 상속을 하려면 public이나 protected로 생성해야 하기 때문에 정적 팩토리 메서드만 제공하면 하위 클래스를 만들 수 없다.
- 정적 팩토리만을 쓰게끔 만드려면 생성자를 private로 만들어야 한다.
- 이 의미는 클래스 상속을 금지한다는 의미이다
- but, 굳이 상속을 사용 안하고 클래스 위임을 통해 더 강력하게 사용할 수 있다.
- 정적 팩토리 메서드를 사용하면서 생성자를 private이 아니고 public으로 사용하는 경우도 있다. ex) ArrayList
- 정적 팩토리 메서드는 프로그래머가 찾기 어렵다.
- 자바doc같은것 작성이 어려움..