Methoden Exception werfen oder nicht

3

349798

Gast
Hallo,

mal angenommen, ich habe eine Methode die ein Dokument einliest und überprüft, ob ein bestimmter Wert vorhanden ist. Ist dieser Wert vorhanden gibt die Methode mir Text aus dem Dokument zurück. Ist dieser Wert nicht vohanden gibt die Methode nichts zurück.
Meine Frage ist nun, ob es angebrachter ist "null" zurückzugeben oder lieber eine Exception werfen?

Danke, für Tipps
 
E

Exception??

Gast
@TO
Das was du beschreibst wäre sog. "Missbrauch von Exceptions" was man laut Conventions vermeiden sollte. Es ist besser fest definierte "Fehler-returns" zu nutzen (also "null" oder "-1" oder der gleichen) anstatt wild mit Exceptions um sich zu werfen.

Auch muss man bei Exceptions zwischen checked und unchecked unterscheiden. Unchecked Exceptions sind RuntimeException und alles was davon erbt. Man sollte während der Entwicklung beim debuggen sicher gehen das keine Unchecked Exceptions geworfen werden und schon gar nicht versuchen diese in try-catch Blöcken zu verarbeiten, denn das ist ein Zeichen für ziemlich schlechten Code.

Als kleines Beispiel vielleicht mal "Thread" :
natürlich kann man einen Thread von außen mit Thread.interrupt() "gewaltsam" abbrechen, sollte man aber vermeiden. Der saubere Weg einen Thread zu beenden ist innerhalb des Threads immer wieder auf ein Laufzeitflag zu prüfen was von außen über einen Setter gesteuert werden kann. Dieses Beispiel kann man auf ziemlich viele andere Fälle übertragen.
Die einzige Ausnahme (meines Wissens) stellen "blocking Methods" dar, also z.B. InputStream.read().
In wie weit es hier "best-practice" gibt wird wohl von Fall zu Fall verschieden sein, aber bewusst Exceptions provozieren (gerade RuntimeException) sollte man wirklich nur als aller letzte Möglichkeit nutzen wenn es wirklich überhaupt nicht anders geht.
 

Ullenboom

Bekanntes Mitglied
Kommt drauf an. Zwei Szenarien:

1. Das Dokument muss in der ersten Zeile eine Kennung tragen, ohne diese Kennung liegt ein Protokollfehler vor.
2. Im Dokument gibt es eine einfache Suche, ein Suchwort kann enthalten sein, muss aber nicht.

Im ersten Fall wirft man eine Ausnahme, weil in interner Fehler vorliegt. Da die Kennung in der Datei sein muss, darf dieser Fehler nicht untergehen und ein Ausnahme zeigt das perfekt an. Ob checked oder unchecked steht auf einem anderen Blatt.

Im zweiten Fall ist eine Ausnahme unangebracht, da es kein Fehler ist, wenn der Suchstring nicht im Dokument ist. Vergleiche das mit String indexOf() oder String matches() -- das würde ja auch keine Ausnahmen werfen, wenn es keine Übereinstimmung gibt.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
I Exception nicht werfen lassen Java Basics - Anfänger-Themen 3
T Eigene Exception - ohne werfen abfangen Java Basics - Anfänger-Themen 2
N Exception werfen bei falscher Datumseingabe Java Basics - Anfänger-Themen 14
P Exception werfen Java Basics - Anfänger-Themen 15
M Exception werfen und bearbeiten Java Basics - Anfänger-Themen 1
A Exception aus Thread werfen Java Basics - Anfänger-Themen 14
D toString überschreiben + Exception werfen Java Basics - Anfänger-Themen 3
S Exception werfen Java Basics - Anfänger-Themen 2
G Comparator- methode compare exception werfen Java Basics - Anfänger-Themen 4
G Exception werfen Java Basics - Anfänger-Themen 4
W Exception werfen nur welche? Java Basics - Anfänger-Themen 17
F eigene Exception aus try-catch werfen Java Basics - Anfänger-Themen 10
D Exception werfen Java Basics - Anfänger-Themen 10
I Exception wird gefangen, aber trotzdem in Error Log? Java Basics - Anfänger-Themen 10
W Null-Pointer Exception beim Programmstart Java Basics - Anfänger-Themen 8
Ostkreuz String Exception Java Basics - Anfänger-Themen 8
Fiedelbambu Exception in Application constructor Java Basics - Anfänger-Themen 3
S leeres Array statt Null Pointer Exception ausgeben Java Basics - Anfänger-Themen 20
F abbruch Exception lässt sich nicht erstellen Java Basics - Anfänger-Themen 2
U Warum kriege ich hier eine nullpointer exception, sehe den Fehler nicht (swing) Java Basics - Anfänger-Themen 1
F Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 11 at main.main(main.java:11) Java Basics - Anfänger-Themen 2
M Exception in thread "main" java.util.NoSuchElementException Java Basics - Anfänger-Themen 2
N Exception beim Verwenden von Arraylist? Java Basics - Anfänger-Themen 10
B Compiler-Fehler Fehlermeldung Exception in thread, falsche Eingabewert Java Basics - Anfänger-Themen 2
S JavaKara Null Exception Error Java Basics - Anfänger-Themen 4
LiFunk Exception: es dürfen nur Nummern eingelesen werden Java Basics - Anfänger-Themen 6
low_in_the_head Eigene Exception nutzen Java Basics - Anfänger-Themen 4
1 Exception Java Basics - Anfänger-Themen 2
S Kriege Fehler "Exception in thread" beim Benutzen von SubStrings. Java Basics - Anfänger-Themen 2
I JAX-RS Exception Handling Java Basics - Anfänger-Themen 4
L Meine erste eigene Exception Klasse Java Basics - Anfänger-Themen 10
J null exception Array Java Basics - Anfänger-Themen 5
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
O Exception in thread "main" java.lang.ArithmeticException: / by zero Java Basics - Anfänger-Themen 4
M Wie kann ich bei int-Variablen im exception handler auf bestimmte Strings reagieren? Java Basics - Anfänger-Themen 5
C Exception-Frage Java Basics - Anfänger-Themen 3
B Exception in thread "AWT-EventQueue-0" java.util.ConcurrentModificationException Java Basics - Anfänger-Themen 8
I Exception bei Button mit wait() und notifyAll() Java Basics - Anfänger-Themen 3
N Wie teste ich eine geworfene Exception? Java Basics - Anfänger-Themen 8
R Methoden ArrayList clonen wirft exception Java Basics - Anfänger-Themen 3
D Scanner- Exception NoSuchElementException Java Basics - Anfänger-Themen 2
A Exception handeling mit finally und objektreferenzen Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
S Exception Java Basics - Anfänger-Themen 2
J Exception-Aufgabe Java Basics - Anfänger-Themen 8
S Verwenden von throw Exception an der Funktion Java Basics - Anfänger-Themen 2
R Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException Java Basics - Anfänger-Themen 5
S Compiler-Fehler Exception in thread "main" java.lang.Error: Unresolved compilation problem: Java Basics - Anfänger-Themen 6
Z Fragen zu Exception (Throws/throw) Java Basics - Anfänger-Themen 7
OSchriever Exception für Abbrechen-Schaltfläche JOptionpane Java Basics - Anfänger-Themen 9
J Dateien in Verzeichnissen rekursiv auflisten wirft Exception Java Basics - Anfänger-Themen 4
J Exception unreachable Java Basics - Anfänger-Themen 12
O unchecked Exception Java Basics - Anfänger-Themen 4
B EJB und Arquillian - bekomme Nullpointer Exception beim Aufruf der EJB Klasse Java Basics - Anfänger-Themen 40
S Exception bei Verwendung von LocalDate Java Basics - Anfänger-Themen 19
I Compiler-Fehler Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 5 Java Basics - Anfänger-Themen 3
D Warum die Nullpointer Exception Java Basics - Anfänger-Themen 6
O Exception behandlung einfach Ueben mit Fakt! Java Basics - Anfänger-Themen 10
I OOP Was ist die "Exception Hierarchie" ? Java Basics - Anfänger-Themen 3
U Null Exception aber keine Ahnung warum Java Basics - Anfänger-Themen 5
G Exception und Ausgabe der Duplikate Java Basics - Anfänger-Themen 6
H Try Catch Throw Exception Java Basics - Anfänger-Themen 1
W Exception in Main abfangen oder in der Methode? Java Basics - Anfänger-Themen 10
F Referenz an ein Objekt in einer anderen Klasse erstellen(Nullpointer exception) Java Basics - Anfänger-Themen 6
Mosquera Exception Java Basics - Anfänger-Themen 5
M rekursive division/0 mit exception Java Basics - Anfänger-Themen 18
N Nullpointer exception Java Basics - Anfänger-Themen 4
L Eigene Exception schreiben bei zu langem Array Java Basics - Anfänger-Themen 10
R Exception in thread "main" java.lang.NullPointerException Java Basics - Anfänger-Themen 10
I equals (Override) mit eigener Exception (keine Runtime-Exception) Java Basics - Anfänger-Themen 9
S Array Grenzen-Exception Java Basics - Anfänger-Themen 11
E InputStream im Servlet wirft Exception Java Basics - Anfänger-Themen 5
D Erste Schritte Java.lang.NullPointer.Exception Java Basics - Anfänger-Themen 8
G Arrays out of Bounds exception Java Basics - Anfänger-Themen 2
H Compiler-Fehler Out of Bunce Exception bei einem Char Java Basics - Anfänger-Themen 6
C Compiler-Fehler Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 2 Java Basics - Anfänger-Themen 3
C Null Pointer Exception Java Basics - Anfänger-Themen 10
F Klassen Eigene Exception Bedingungen festlegen Java Basics - Anfänger-Themen 2
G Null Pointer Exception Java Basics - Anfänger-Themen 4
GreenTeaYT Exception und zur OOP fragen? Java Basics - Anfänger-Themen 3
O Exception bei Parse-Vorgang Java Basics - Anfänger-Themen 17
T Exception Problem Java Basics - Anfänger-Themen 5
Z Getter/Setter NullPointer Exception Java Basics - Anfänger-Themen 6
W Nullpointer Exception bei .add(...) Java Basics - Anfänger-Themen 6
L Input/Output InputMismatch.Exception Java Basics - Anfänger-Themen 7
B Exception Liste von Liste Java Basics - Anfänger-Themen 3
D Throw Exception Java Basics - Anfänger-Themen 2
MiMa JavaDoc Exception @throws schlagen an Java Basics - Anfänger-Themen 4
J Exception in thread "main" Java Basics - Anfänger-Themen 1
B Exception richtig einbinden Java Basics - Anfänger-Themen 1
M Exception soll Werte mitgeliefert bekommen Java Basics - Anfänger-Themen 12
M Selbstdefinierte Exception Java Basics - Anfänger-Themen 5
B Exception Throwable Java Basics - Anfänger-Themen 11
M Erste Schritte Start Methode - Exception Java Basics - Anfänger-Themen 1
F Operatoren Wieso fliegt hier eine NullPointer Exception :( Java Basics - Anfänger-Themen 3
F nullpointer exception - arrayerstellung Java Basics - Anfänger-Themen 4
K Iterator-Interface implementieren mit Exception Handlung Java Basics - Anfänger-Themen 1
H Erste Schritte Exception: 0 Java Basics - Anfänger-Themen 2
A Exception vs. Testklasse (Programm testen) Java Basics - Anfänger-Themen 2
L Fehler: Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben