확인된 예외에 대한 반대
수년 동안 나는 다음 질문에 대해 적절한 답을 얻을 수 없었습니다. 일부 개발자는 왜 그렇게 반대합니까? 이상하게 확인됐나요? 나는 여러 대화를 나누고, 블로그 게시물을 읽고, Bruce Eckel의 관점을 읽었습니다(그는 내가 본 첫 번째 사람입니다).
현재 새로운 코드를 작성 중인데 예외 처리 방법에 매우 주의하고 있습니다. 나는 "우리는 확인된 예외를 좋아하지 않는다"는 군중의 관점을 이해하려고 노력하고 있지만 여전히 이해할 수 없습니다.
모든 대화는 답도 없이 같은 질문으로 끝났습니다... 설정해 보겠습니다:
일반적으로 말하면 (Java 설계에 따라)
예외가 발생하면 개발자가 할 수 있는 일은 프로그램을 종료하는 것뿐이라는 말을 자주 듣습니다.
내가 듣는 또 다른 일반적인 주장은 확인된 예외로 인해 코드를 리팩터링하기가 더 어렵다는 것입니다.
'그냥 그만뒀다'는 주장은 그만둔다 해도 합당한 오류 메시지를 보여줘야 한다는 뜻이다. 오류 처리만 피한다면 이유를 명확히 밝히지 않고 프로그램이 종료될 때 사용자는 별로 기뻐하지 않을 것입니다.
"리팩토링이 어렵다"는 군중의 경우 이는 적절한 추상화 수준이 선택되지 않았음을 의미합니다. 메소드가 IOException을 발생시킨다고 선언하는 대신, IOException은 현재 상황에 더 적합한 예외로 변환되어야 합니다.
프로그램이 정상적으로 종료되도록 Main을 catch(Exception)(또는 어떤 경우에는 catch(Throwable))으로 래핑하는 데 문제가 없습니다. 하지만 항상 잡아야 하는 특정 예외를 잡아냅니다. 이렇게 하면 최소한 적절한 오류 메시지를 표시하도록 허용합니다.
사람들이 결코 대답하지 않는 질문은 다음과 같습니다.
대신 RuntimeException
하위 클래스를 던지면 예외
, 그런데
무엇을 잡아야 하는지 어떻게 알 수 있나요?
.
스택 추적을 보여주는 프로그램이 잘못되었다고 말하고 싶습니다. 체크 예외를 좋아하지 않는 사람들도 그렇게 생각하지 않나요?
그럼 확인된 예외가 마음에 들지 않는다면 그 이유를 설명해 주실 수 있나요? 그리고 답이 없는 질문에 답하시겠습니까?
두 모델 중 하나를 사용하는 것에 대한 조언을 구하는 것이 아니라 사람들이 Exception 대신 RuntimeException에서 확장하는 이유와 예외를 포착한 다음 다시 발생시키는 이유를 찾고 있습니다. 하나는 메서드에 RuntimeException throw를 추가하는 대신입니다. 확인된 예외를 좋아하지 않는 이유를 알고 싶습니다.
위 내용은 일부 개발자가 Java의 확인 예외를 반대하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!