Java ‐ 비검사 경고를 제거하라[Effective Java Item 27] - dnwls16071/Backend_Summary GitHub Wiki

비검사 경고를 제거하라

  • 할 수 있는 한 모든 비검사 경고를 제거하라.
  • 모두 제거한다면 그 코드는 타입 안전성이 보장된다.
  • 즉, 런타임에 ClassCastException이 발생할 일이 없고, 여러분이 의도한 대로 잘 동작하리라 확신할 수 있다.
  • 경고를 제거할 수 없지만 타입 안전하다고 확신할 수 있다면 @SuppressWarnings("unchecked") 어노테이션을 달아 경고를 숨기자.
  • 단, 타입 안전함을 검증하지 않은 채 경고를 숨기면 스스로에게 잘못된 보안 인식을 심어주게 된다.
  • 또한 @SuppressWarnings("unchecked") 어노테이션은 항상 가능한 한 좁은 범위에 적용하자.
// Good
public <T> T[] toArray(T[] a) {
    if (a.length < size) {
	// 생성한 배열과 매개변수로 받은 배열의 타입이 모두 T[]로 같으므로 올바른 형변환이다.
	@SuppressWarnings("unchecked")
	T[] result = (T[]) Arrays.copyOf(elementData, size, a.getClass());
        return result;
    }

    System.arraycopy(elementData, 0, a, 0, size);
    if (a.length > size)
        a[size] = null;
    return a;
}
  • 위와 같이 @SuppressWarnings("unchecked") 어노테이션을 사용할 때면 그 경고를 무시해도 안전한 이유를 항상 주석으로 남겨야 한다.
  • 다른 사람이 그 코드를 이해하는 데 도움이 되며, 더 중요하게는 다름 사람이 코드를 잘못 수정해 타입 안전성이 잃는 상황을 줄여준다.