Geprüfte Ausnahmen sind ein leistungsstarkes Werkzeug in Java, da sie den Programmierer dazu zwingen, mit außergewöhnlichen Bedingungen umzugehen, was die Codezuverlässigkeit erhöht. Allerdings kann eine übermäßige Nutzung die Verwendung von APIs erschweren. Damit eine geprüfte Ausnahme gerechtfertigt ist, muss die Situation wirklich außergewöhnlich sein und für den Programmierer sinnvolle Maßnahmen erforderlich machen. Andernfalls ist möglicherweise eine nicht aktivierte Ausnahme angemessener.
Java 8 brachte eine zusätzliche Herausforderung bei der Verwendung geprüfter Ausnahmen mit sich, da Methoden, die sie auslösen, nicht direkt in Streams verwendet werden können, was eine zusätzliche Behandlung im Code erfordert. Um diese Komplexität zu vermeiden, können Alternativen in Betracht gezogen werden, z. B. die Rückgabe eines optionalen Objekts anstelle des Auslösens einer überprüfbaren Ausnahme oder die Aufteilung der Methode in zwei, eine, die auf die Möglichkeit eines Fehlers prüft, und eine andere, die den Vorgang ausführt.
Geprüfte Ausnahmen sollten sparsam verwendet werden: Wenn eine Wiederherstellung nicht möglich ist, verwenden Sie ungeprüfte Ausnahmen. Wenn eine Wiederherstellung möglich ist, ziehen Sie die Option „Optional“ für die Rückgabe in Betracht. Wenn dies nicht genügend Informationen liefert, kann eine geprüfte Ausnahme gerechtfertigt sein.
Plus:
Hier sind einige Beispiele, um die ordnungsgemäße Verwendung von geprüften Ausnahmen und Alternativen wie Optional und die Verwendung von Prüfmethoden zu veranschaulichen.
Geprüfte Ausnahmen sparsam verwenden
Nehmen wir an, wir haben eine Methode, die Daten aus einer Datei lädt. Wenn die Datei nicht gefunden wird, möchten wir eine Ausnahme auslösen, um den Aufrufer über das Problem zu informieren. In diesem Fall ist eine aktivierte Ausnahme angemessen, da der Entwickler Maßnahmen ergreifen kann, um das Problem zu beheben (z. B. Bereitstellung des richtigen Archivpfads).
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"; } }
Hier muss der Aufrufer die FileNotFoundException-Ausnahme behandeln, da er das Problem beheben kann, indem er einen korrekten Pfad zur Datei angibt.
Optionale statt geprüfte Ausnahmen verwenden
Wenn es sich bei der fehlenden Datei um eine Bedingung handelt, die die normale Ausführung nicht unterbrechen sollte, können wir mit Optional angeben, dass das Ergebnis fehlen kann, ohne eine Ausnahme auszulösen. Dies macht die API flüssiger für Fälle, in denen ein Mangel an Wert toleriert werden kann.
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"); } }
Im Anrufercode:
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.") );
In diesem Beispiel muss der Aufrufer keine Ausnahmen behandeln, und Optional ermöglicht ihm eine reibungslosere Behandlung fehlender Inhalte.
Unterteilung der Methode in zwei Teile: Verifizierung und Aktion
In manchen Fällen können wir die Methode in zwei Teile unterteilen: eine, die die Bedingung prüft, und eine andere, die die Aktion ausführt. Dadurch kann der Aufrufer die Ausnahmebedingung behandeln, bevor er die Hauptmethode aufruft, wodurch die API flexibler wird.
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"; } }
Im Anrufercode:
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"); } }
Hier verwenden wir IllegalStateException, eine ungeprüfte Ausnahme für den Fall, dass der Aufrufer versucht, die Datei zu laden, ohne vorher zu prüfen, ob sie verfügbar ist.
Zusammenfassung
Geprüfte Ausnahme: Wird für Bedingungen verwendet, die der Aufrufer direkt beheben kann, z. B. FileNotFoundException für Dateien.
Optional: Verwenden Sie diese Option, wenn das Fehlen eines Werts den Programmablauf nicht unterbrechen soll.
Methodenaufteilung: Separate Prüf- und Ausführungsmethoden, wenn der Fehler vorhergesagt und vermieden werden kann, wodurch die API flexibler und benutzerfreundlicher wird.
Das obige ist der detaillierte Inhalt vonArtikel Vermeiden Sie die unnötige Verwendung von geprüften Ausnahmen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!