검사된 예외는 프로그래머가 예외적인 조건을 처리하도록 하여 코드 안정성을 높이는 Java의 강력한 도구입니다. 그러나 과도하게 사용하면 API 사용이 어려워질 수 있습니다. 확인된 예외가 정당화되려면 상황이 정말로 예외적이고 프로그래머 측에서 유용한 조치를 취할 수 있어야 합니다. 그렇지 않으면 확인되지 않은 예외가 더 적절할 수 있습니다.
Java 8에서는 확인된 예외를 발생시키는 메서드를 스트림에서 직접 사용할 수 없어 코드에서 추가 처리가 필요하기 때문에 확인된 예외 사용에 추가적인 문제가 발생했습니다. 이러한 복잡성을 피하기 위해 검증 가능한 예외를 발생시키는 대신 Optional 개체를 반환하거나 메서드를 오류 가능성을 확인하는 메서드와 작업을 수행하는 메서드로 분할하는 등의 대안을 고려할 수 있습니다.
확인된 예외는 자제해서 사용해야 합니다. 복구가 불가능할 경우 확인되지 않은 예외를 사용하세요. 복구가 가능한 경우 반품 옵션을 고려하세요. 이것이 충분한 정보를 제공하지 않으면 확인된 예외가 정당화될 수 있습니다.
추가:
다음은 Optional 및 check 메소드 사용과 같은 확인된 예외 및 대안의 올바른 사용을 설명하는 몇 가지 예입니다.
Checked Exception을 적게 사용하기
파일에서 데이터를 로드하는 메서드가 있다고 가정해 보겠습니다. 파일을 찾을 수 없으면 호출자에게 문제를 알리기 위해 예외를 발생시키고 싶습니다. 이 경우 개발자가 문제 해결을 위한 조치(예: 올바른 아카이브 경로 제공)를 취할 수 있으므로 확인된 예외가 적합합니다.
public class FileLoader { public String loadFile(String filePath) throws FileNotFoundException { File file = new File(filePath); if (!file.exists()) { throw new FileNotFoundException("Arquivo não encontrado: " + filePath); } // Código para carregar o arquivo return "Conteúdo do arquivo"; } }
여기서 호출자는 파일에 대한 올바른 경로를 제공하여 문제를 해결할 수 있으므로 FileNotFoundException 예외를 처리해야 합니다.
Checked Exception 대신 Optional 사용
누락된 파일이 정상적인 실행을 방해해서는 안 되는 조건인 경우 Optional을 사용하여 예외를 발생시키지 않고 결과가 누락될 수 있음을 나타낼 수 있습니다. 이는 가치 부족이 허용될 수 있는 경우에 API를 더욱 유연하게 만듭니다.
import java.util.Optional; public class FileLoader { public Optional<String> loadFile(String filePath) { File file = new File(filePath); if (!file.exists()) { return Optional.empty(); } // Código para carregar o arquivo return Optional.of("Conteúdo do arquivo"); } }
발신자 코드:
FileLoader loader = new FileLoader(); Optional<String> content = loader.loadFile("caminho/para/arquivo.txt"); content.ifPresentOrElse( System.out::println, () -> System.out.println("Arquivo não encontrado.") );
이 예에서 호출자는 예외를 처리할 필요가 없으며 Optional을 사용하면 누락된 콘텐츠를 보다 원활하게 처리할 수 있습니다.
검증과 조치의 두 가지 방식으로 나누어 보기
어떤 경우에는 메서드를 조건을 확인하는 메서드와 작업을 수행하는 메서드로 나눌 수 있습니다. 이를 통해 호출자는 기본 메서드를 호출하기 전에 예외 조건을 처리할 수 있으므로 API가 더욱 유연해집니다.
public class FileLoader { public String loadFile(String filePath) throws FileNotFoundException { File file = new File(filePath); if (!file.exists()) { throw new FileNotFoundException("Arquivo não encontrado: " + filePath); } // Código para carregar o arquivo return "Conteúdo do arquivo"; } }
발신자 코드:
import java.util.Optional; public class FileLoader { public Optional<String> loadFile(String filePath) { File file = new File(filePath); if (!file.exists()) { return Optional.empty(); } // Código para carregar o arquivo return Optional.of("Conteúdo do arquivo"); } }
여기에서는 호출자가 파일의 사용 가능 여부를 먼저 확인하지 않고 파일을 로드하려고 시도하는 경우 확인되지 않은 예외인 IllegalStateException을 사용합니다.
요약
확인된 예외: 파일에 대한 FileNotFoundException과 같이 호출자가 직접 수정할 수 있는 조건에 사용합니다.
선택 사항: 값이 없어도 프로그램 흐름이 중단되어서는 안 되는 경우에 사용하세요.
메서드 분할: 오류를 예측하고 방지할 수 있는 경우 검사 방법과 실행 방법을 분리하여 API를 더욱 유연하고 사용하기 쉽게 만듭니다.
위 내용은 항목 Checked Exception의 불필요한 사용 방지의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!