본문 바로가기
개발/JAVA

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

by JaeHoist 2022. 12. 27.

정적 팩토리 메서드 사용의 장점 5가지

  1. 이름을 가질 수 있다
    1. 이름만 잘 지으면 반환될 객체의 특성을 쉽게 묘사할 수 있다.
      (ex: BigInteger.probablePrime = 값이 소수인 BigInteger를 반환한다.)
  2. 호출될 때 마닥 인스턴스를 새로 생성하지 않아도 된다.
    1. 같은 객체가 자주 요청되는 상황이라면 성능을 상당히 끌어올려 준다.
  3. 반환 타입의 하위 타입 객체를 반환할 수 있는 능력이 있다.
    1. 반환할 객체의 클래스를 자유롭게 선택할  수 있는 유연성
  4. 입력 매개변수에 따라 매번 다른 클래스의 객체를 반환 할 수 있다.
    1. 반환 타입의 하위 타입이기만 하면 어떤 클래스의 객체를 반환하든 상관없다.
  5. 정적 팩토리 메서드를 작성하는 시멎ㅁ에는 반환할 객체의 클래스가 존재하지 않아도 된다.
    1. 서비스 제공자 프레임워크를 만드는 근간이 되는 유연함을 가진다.

정적 팩토리 메서드 사용의 단점 2가지

  1. 하위 클래스를 만들 수 없다.
    1. 상속을 하려면 public이나 protected 생성자가 필요하니
      정적 팩토리 메서드만 제공하면 하위클래스를 만들 수 없다.
  2. 개발자가 찾기 어렵다.
    1. API 설명에 명확히 드러나지 않으니,
      정적 팩토리 메서드 방식 클래스를 인스턴스화할 방법을 알아내야 한다.
    2. API 문서를 잘 써놓고,
      메서드 이름도 널리 알려진 규약을 따라 짓는 식으로 문제를 완화해야 한다.
      from 매개 변수 한개를 받아 해당 타입 인스턴스 반환
      of 여러 매개변수를 받아 적합한 타입의 인스턴스 반환