static 메서드와 static 필드만을 담은 유틸리티 클래스는 객체 지향과 거리도 멀지만, 쓰임새가 있다. 하지만, 해당 클래스를 abstract로 만들어도, 상속 받아서 인스턴스를 만들 수 있기 때문에 인스턴스를 만드는 걸 막을 순 없다.
아무런 생성자를 만들지 않은 경우에도 컴파일러가 기본적으로 아무 인자가 없는 public 생성자를 만들어주기 때문에 그런 경우에도 인스턴스를 만들 수 있다.
따라서 인스턴스화를 막기 위해선 명시적으로 private 생성자를 추가해야 한다.
(참고, Spring에서 Utility class를 만들기 위해선 주로 abstract로 선언하고 있음. 상속해서 생성자를 만들어봤자, 그 생성자로 생성한 인스턴스로 Utility class의 멤버에 접근할 수 없음)
java.lang.Math
, java.util.Arrays
java.util.Collections
이와 같이 정적 멤버만 담은 유틸리티 클래스는 인스턴스로 만들어 쓰려고 설계한 게 아니다.
but, 생성자를 명시하지 않으면 컴파일러가 자동으로 기본 생성자(매개변수 없는 public)를 만들어준다.
인스턴스를 만들 수 없는 유틸리티 클래스
public class UtilityClass {
// 기본 생성자가 만들어지는 것을 막는다(인스턴스화 방지용)
private UtilityClass() {
throw new AssertionError(); // 생성자 내부 호출 시 명시적인 에러 던지기
}
...
}
Assertion Error
를 던져 클래스 안에서 실수로라도 생성자를 호출하지 않도록 해준다.