본문 바로가기
책/이펙티브 자바 3판

[아이템 1] 생성자 대신에 정적 팩토리 메서드 패턴을 고려하라.

by eunyoung 2023. 4. 18.

이펙티브 자바 2장 - 객체 생성과 파괴 

[아이템 1] 생성자 대신에 정적 팩토리 메서드 패턴을 고려하라.


클라이언트가 클래스의 인스턴스를 얻는 방법

  • public 생성자 사용(전통적인 방법)

  • 정적 팩터리 메서드(static factory method)(public 생성자 이외의 다른 방법)

    그 클래스의 인스턴스를 반환하는 단순한 정적 메서드 


public 생성자 대신에 정적 팩터리 메서드를 사용하는 것의 장점

 

  • 이름을 가질 수 있다.

  • 호출할 때마다 인스턴스를 새로 생성하지 않아도 된다.

  • 반환 타입의 하위 타입 객체를 반환할 수 있는 능력이 있다.

    인터페이스를 정적 팩터리 메서드의 반환 타입으로 사용하는 인터페이스 기반 프레임워크를 만드는 핵심 기술.
  • 입력 매개변수에 따라서 매번 다른 클래스의 객체를 반환할 수 있다.

  • 정적 팩터리 메서드를 작성하는 시점에 반환할 객체의 클래스가 존재하지 않아도 된다.

public 생성자 대신에 정적 팩터리 메서드를 사용하는 것의 단점

  • 상속을 하려면 public이나 protected 생성자가 필요하니 정적 팩터리 메서드만 제공하면 하위 클래스를 만들 수 없다.

  • 정적 팩터리 메서드는 프로그래머가 찾기 어렵다.

[핵심 정리]

 

정적 팩터리 메서드와 public 생성자는 각자의 쓰임새가 있으니 상대적인 장단점을 이해하고 사용하는 것이 좋음.

정적 팩터리를 사용하는 것이 유리한 경우가 더 많으므로 무작정 public 생성자를 사용하는 습관이 있으면 고치는 것이 좋음.