[이펙티브자바]아이템1. 생성자 대신 정적 팩토리 메서드를 고려하라

JP·2022년 7월 9일
0

자바

목록 보기
8/10

생성자 대신 정적 팩토리 메서드를 고려하라

  • 대부분의 상황에서는 생성자가 유효하다
  • 정적 팩토리 메서드가 유효한 상황이 있다
    - 생성자는 이름을 표현할 수 없다.
    • 동일한 매개변수 시그니쳐와 순서를 갖는 생성자는 하나만 존재해야 한다는 제약 조건
      public Order(Product product, boolean prime){}
      public Order(Product product, boolean urgent){} // compile error
    • 에러를 피하기 위해 매개변수의 순서를 바꾸는 방법도 있지만 그렇게 한다고 생성자로 어떠한 객체를 만드려는지 의도 표현이 안됨.
    • 이러한 문제를 해결하기 위헤 정적 팩토리 메서드를 사용.

정적 팩토리 메서드를 사용하는 방법

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;
}

정적 팩토리 메서드의 장점은?

  1. 이름을 가질 수 있다.
public static primeOrder(Product prodcut){..}
public static urgentOrder(Product product){..}
  1. 호출될 때마다 인스턴트를 새로 생성하지 않아도 된다.
  • 객체 생성을 외부가 아니라 자신이 컨트롤 한다는 의미 ex) Boolean.valueOf(boolean);
  1. 변환 타입의 하위 타입 객체를 반환할 수 있는 능력이 있다.
  • interface타입 사용 가능
  • 클래스를 선언해놓고 그 클래스의 하위 타입 사용 가능
  • 입력 매개변수에 따라 매번 다른 클래스의 객체를 반환할 수 있다.
public static HelloService of(String lang){
	if("ko".equals(lang){}
    else {..}
}
  1. 정적 팩토리 메서드를 작성하는 시점에는 반환할 객체의 클래스가 존재하지 않아도 된다.

정적 팩토리 메서드의 단점은?

  1. 상속을 하려면 public이나 protected로 생성해야 하기 때문에 정적 팩토리 메서드만 제공하면 하위 클래스를 만들 수 없다.
  • 정적 팩토리만을 쓰게끔 만드려면 생성자를 private로 만들어야 한다.
  • 이 의미는 클래스 상속을 금지한다는 의미이다
    - but, 굳이 상속을 사용 안하고 클래스 위임을 통해 더 강력하게 사용할 수 있다.
    - 정적 팩토리 메서드를 사용하면서 생성자를 private이 아니고 public으로 사용하는 경우도 있다. ex) ArrayList
  • 정적 팩토리 메서드는 프로그래머가 찾기 어렵다.
    - 자바doc같은것 작성이 어려움..
    • 따라서 커멘트를 열심히 달아야 함.!
profile
to Infinity and b

0개의 댓글