이따금 단순히 static method와 static field만을 담은 class를 만들고 싶을 때가 있을 것이다.
java.lang.Math와 java.utils.Arrays 처럼 기본 타입 값이나 배열 관련 method들을 모아놓을 수도 있다.
이와 같은 static member만 담은 utility class는 인스턴스로 만들어 쓰려고 설계한게 아니다.
즉, 이 객체들은 인스턴스화를 막았기 때문에 아래와 같이 코드를 작성할 수 없다.
Math math = new Math();
Arrays arrays = new Arrays();
또한, 생성자를 명시하지 않으면 Compiler가 자동으로 기본 public 생성자를 만들어 준다.
이로인해 의도치않게 인스턴스화할 수 있게 된 class가 만들어질 수 있다.
그리고 추상 클래스로 만드는 것으로는 인스턴스화를 막을 수 없다. 하위 클래스를 만들어 인스턴스화 하면 그만이기 때문이다.
이는 상속해서 쓰라는 뜻으로 오해할 수 있으니 더욱 문제가 될 수 있다.
따라서 불필요한 인스턴스화를 막기 위해선, private 생성자를 추가하면 된다.
public class UtilityClass{
// 기본 생성자가 만들어지는 것을 막는다 (인스턴스화 방지용).
private UtilityClass(){
throw new AssertionError();
}
...
}
명시적 생성자가 private이니 클래스 바깥에서는 접근할 수 없으며 클래스 안에서 실수라도 생성자를 호출하지 않도록 private 생성자 안에 AssertionError를 던질 수 있다.
그리고 모든 생성자는 명시적이든 묵시적이든 super 클래스의 생성자를 호출하게 되는데 이처럼 private으로 선언된 class일 경우 상위 클래스 생성자에 접근할 길이 막혀 버려 상속이 불가능 해진다