Frage zu Exceptionhandling

Maik.Neumann

Aktives Mitglied
Guten Tag,

ich habe mal eine Frage zu dem Exceptionhandling in Java. Nun ist es ja so, dass CheckedExceptions (wie z.B. eine FileNotFoundException) explizit von mir als Programmierer behandelt werden müssen und die UncheckedException (wie z.B. eine ArrayIndexOutOfBoundsException) kann von mir behandelt werden, muss sie aber nicht.

Nun könnte ich ja die Exception direkt in der Methode behandeln, in der sie auftritt, oder eben mit throws an den Aufrufer der entsprechenden Methode weitergeben, wenn ich Sie nicht behandeln möchte.

Unter dem Aspekt der Wiederverwendung einer Klasse inkl. derer Methoden stellt sich für mich die folgende Frage:

Wann macht es Sinn etwas direkt in der Methode zu behandeln und wann macht es Sinn, eine Exception weiterzuwerfen? Und wenn ich Sie weiterwerfe, wo solte sie dann behandelt werden?

Ich wei, dass das auch sehr vom Gesamtkontext meiner Anwendung abhängt, aber gibt es da eine Art Faustregel?

Danke und Gruß
 

turtle

Top Contributor
wo solte sie dann behandelt werden?
It depends;)

Das ist (natürlich) abhängig von der Exception und dem Kontext.

Nehmen wir dein Beispiel FileNotFoundException.

Wie kann da eine Behandlung aussehen?

Dem User wird ein JFileChooser angeboten und geprüft, ob Datei vorhanden und lesbar ist.

Kommt beim Zugriff die Exception kann wieder der JFileChooser aufgehen und der User kann erneut eine Datei auswählen. Also KANN hier eine sinnvolle Bahndlung gemacht werden.

Beim Starten der Applikation liest das Programm Einstellungen aus einer Konfigurationsdatei. Wie kann hier eine Behandlung aussehen? Wenn das Programm nicht ohne Einstellungen arbeiten kann, ist KEINE sinnvolle Behandlung möglich und die Exception sollte weiter geworfen werden.

Im Bereich der Datenbank gibt es beispielsweise viele unterschiedliche SQLExceptions, unter anderem wenn eine Verbindung zur Datenbank hergestellt wird. In den seltensten Fällen kann hier eine sinnvolle Behandlung gemacht werden...

gibt es da eine Art Faustregel?
Nein,lies obige Begründung;)
 

Maik.Neumann

Aktives Mitglied
Danke für deinen Beitrag !

Wenn das Programm nicht ohne Einstellungen arbeiten kann, ist KEINE sinnvolle Behandlung möglich und die Exception sollte weiter geworfen werden.

Wohin würdest Du sie denn in diesem Fall werfen? Mir ist das Wurfziel und eine mögliche Abhandlung dieser Exception nicht klar.

In den seltensten Fällen kann hier eine sinnvolle Behandlung gemacht werden...

Auch hier ist mir nicht ganz klar, wohin die Exception geworfen werden sollte und vor allem, wie sie einmal behandelt werden soll, sobald sie geworfen wurde.
 

Natac

Bekanntes Mitglied
Die Frage ist: Wer KANN die Exception sinnvoll behandeln?

Wenn du sinnvoll auf eine Exception reagieren kannst, dann fange sie und reagiere darauf.
Wenn du nicht sinnvoll auf eine Exception reagieren kannst, dann wirf sie weiter.

Wer über dir in der Kette steht, weißt du als aufgerufenes Stück Code ja meistens nicht. Und es ist auch prinzipiell gut darüber keine Annahmen zu machen.

In meinen Applikationen setzte ich möglichst früh ein DefaultUncaughtExceptionHandler, der aufgerufen wird, wenn eine Exception bis zur VM durchgeflogen ist. Meistens gibt der dann eine Fehlermeldung aus und schreibt die Exception in ein logfile. Viel mehr kann man an dieser Stelle dann auch nicht mehr machen. Zumindest sieht der Nutzer so, dass es einen Fehler gab und ich hab eine Datei, in der ich mir das anschauen kann.
 

turtle

Top Contributor
Wohin würdest Du sie denn in diesem Fall werfen? Mir ist das Wurfziel und eine mögliche Abhandlung dieser Exception nicht klar.
Das hat Natac schon richtig beschrieben. Bleiben wir beim Beispiel
Java:
    public void readEinstellungen(File file) throws FileNotFoundException {
	BufferedReader bufferedReader = new BufferedReader(new FileReader(file));
	// ...
    }
Du siehst, es gibt keine sinnvolle Behandlung also werfen wir die Exception weiter. Das bedeutet, das sich "jemand" darum kümmern sollte. Man sagt auch, die Exception wird im Call-Stack hochgereicht, bis einer die Exception behandelt. Wie ebenfalls Natac richtig sagte, kann man einen Handler registrieren, der quasi die letzte Ausfahrt der JVM darstellt. Ansonsten würde die JVM das Programm abbrechen.
 

Maik.Neumann

Aktives Mitglied
Danke für eure bisherigen Beiträge !

Wer über dir in der Kette steht, weißt du als aufgerufenes Stück Code ja meistens nicht. Und es ist auch prinzipiell gut darüber keine Annahmen zu machen.

Das bedeutet im Umkehrschluss aber auch, dass in ""höcherliegenden" Methoden zusätzliche throws Deklarationen in die Methodenköpfe eingefügtw erden müssen (u.U. auch sehr viele und sehr viele speziellierte Exceptions).

Führt das aber wieder nicht zu stark aufgeblähten Methodenköpfen und ggf. komplexeren Code? Was wäre hier eine mögliche Abhilfe? Einfach nur throws Exception schreiben?

Danke und Gruß
 

turtle

Top Contributor
Was wäre hier eine mögliche Abhilfe?
Das wird sehr kontrovers diskutiert im Java-Lager:D

Die eine Fraktion befürwortet den Verzicht auf checked Exceptions und mehr Runtime Exceptions.
Die andere Fraktion findet den Status-Quo ausreichend.

Ich sehe das etwas differenzierter und führe als Beispiel SQLExceptions an.

Es gibt Code, der auf Datenbanken zugreift und häufig benutzt man dazu ein ORM-Framework wie Hibernate. Ein Problem mit checked Exceptions ist, das nun unterliegend SQLExceptions auftreten können, diese nach oben gereicht werden und dort in der Business-Logik der Applikation auftreten. Dieses betrachten viele als Leck (leak), weil Implementierungsdetails in Schichten sichtbar sind, die das eigentlich nichts angeht. Daher wurde in Hibernate die HibernateException eingefügt, eine Runtime-Exception, die derartige Probleme verhindert.

Daher finde ich, das Exceptions SEHR genau entworfen gehören und man einen Kompromiss zwischen klarem Code, Aussagefähigkeit und Wartbarkeit finden muss.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Frage zum Quellcode - Zusammhänge und Ablauf. Java Basics - Anfänger-Themen 2
D Erste Schritte Frage eines absoluten Anfängers Java Basics - Anfänger-Themen 3
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
N Best Practice Frage zum MVC-Pattern Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7
B Fachliche Frage bei Rechnungen Java Basics - Anfänger-Themen 16
B Frage zu: String... strings -> Ungleiche Anzahl an Parameter? Java Basics - Anfänger-Themen 4
B Frage zu Datenbank Design - Rechnungen, Angebote... und deren Positionen Java Basics - Anfänger-Themen 4
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben