Rückgabe nicht sinnvoll: Exception oder null zurück?

Status
Nicht offen für weitere Antworten.

Redfrettchen

Bekanntes Mitglied
Hi,
was ist schöner/eleganter, wenn eine Rückgabe nicht sinnvoll ist:
1. throw Exception oder
2. null zurückgeben?

Also konkret möchte ich den Schnittpunkt einer Strecke mit einer anderen Strecke berechnen lassen. Sollten die Strecken parallel oder identisch sein, löse ich schon mal ne Exception aus, da der Benutzer vorher mit isParallel() oder equals() diese Fälle hätte prüfen können. Sollten die Geraden, dessen Teilmenge die Strecken sind, sich allerdings schneiden, kann es ja immer noch sein, dass eine oder beide Strecken um den Schnittpunkt herum nicht definiert ist, d.h. der Schnittpunkt nicht zwischen den definierenden Punkten liegt. Sollte ich hier auch eine Exception auslösen, oder einfach null als Schnittpunkt zurückgeben?

Bei Exceptions wird ja immer aufwendig der Stack gezogen, also spricht die Performance für null. null ist allerdings eine im Grunde nichtssagende Antwort auf den Methodenaufruf. In diesem Fall könnte man ja noch argumentieren, dass null nur zurückgegeben wird, wenn sich zwar die Geraden, aber nicht die Strecken schneiden.
 
L

LazyL

Gast
Also null zurückgeben ist immer problematisch, da es schnell zu NullpointerExceptions an anderer Stelle kommen kann, und dann die Fehler Suche manchmal etwas dauern kann. Also würde ich dazu raten eine Exception zu werfen.
Eine weitere Möglichkeit ist das Vertragsmodell mit Vor- und Nachbedingungen durch assertions zu realisieren, was vielleicht auch bei Parallelität und Gleichheit eleganter wäre.
 

byte

Top Contributor
Naja, Assertions müssen ja beim Ausführen explizit aktiviert werden (oder wurde das mit Java 5 geändert?). Desweiteren nutzt Du sie zum Auffinden und Korrigieren von Bugs. In diesem Fall scheint es ja wenn ich richtig verstanden habe kein Bug zu sein, wenn die Berechnung mit zwei parallelen Strecken aufgerufen wird. Null zurückgeben funktioniert natürlich solange, wie Du bei jedem Aufruf der Methode den Fall "null als Rückgabe" weiter behandelst. Vergisst Du das mal, kriegst Du ne NullPointerException. Demnach ist es imo sauberer, wenn Du ne Exception wirfst in Deiner Berechnung, z.B. ne IllegalArgumentException oder Du definierst Dir eine eigene. Dann wirst Du gezwungen, diese Exception auch zu catchen und vermeidest Fehler, die sonst z.B. bei Wiederverwendung der Methode zu einem späteren Zeitpunkt durch Dich oder irgendjemand anderen auftreten könnten.
 

Bleiglanz

Gesperrter Benutzer
in dem Fall wäre ich für null

(müsste halt in der javadoc genau spezifiziert werden)

Code:
if(null!=schnittpunkt){

}

find ich halt irgendwie schöner als die Exception - und es ist ja auch keine "Ausnahme" wenn sich zwei Geraden mal nicht schneiden...
 

norman

Top Contributor
normalerweise könnte man es doch auch etwa so machen::
Code:
Point schnittpunkt;
if (schnittpunktExists(gerade1, gerade2) {
   schnittpunkt = getSchnittpunkt(gerade1, gerade2)
}
für den Fall, dass hier kein Schnittpunkt exisitert, bleibt schnittpunkt ja auch null... ???:L
=> ich finde null also durchaus logisch an dieser stelle
 
B

bygones

Gast
ich würde noch ne boolean methode intersects oder so einbauen, die überprüft, ob sich 2 geraden schneiden....
 

Redfrettchen

Bekanntes Mitglied
Jo, hab ich auch, aber wenn man beides aufruft hat man halt doppelte Arbeit. Da fänd ich aber Exception/null besser.
 

Dante

Bekanntes Mitglied
eine exception ist eine Ausnahme, also irgendein Fehler in der Applikation der noch die Chance hätte bearbeitet zu werden, imho ist der hier genannte Fall aber kein fehler sondern einfach nur ein möglicher Rückgabewert eines Algorithmus, daher sollte null zurückgegeben werden, um anzuzeigen das es keinen Schnittpunkt gibt
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
R Rückgabe eines Arrays durch Funktion Allgemeine Java-Themen 9
D Problem mit der Rückgabe von Raw-Types Allgemeine Java-Themen 2
S Java Problem bei der Rückgabe eines Arrays Allgemeine Java-Themen 19
S Polymorphie generischer Rückgabe-Typ Allgemeine Java-Themen 4
R Methoden Rückgabe Arrays aufangen Allgemeine Java-Themen 29
M Einmalige Rückgabe eines Wertes? Allgemeine Java-Themen 8
H SQL Update "Rückgabe der DB als String?" Allgemeine Java-Themen 7
S Rückgabe Allgemeine Java-Themen 6
R Rückgabe 2 Werte Allgemeine Java-Themen 5
I Rückgabe eines Arrays aus einer Methode, wie sicher? Allgemeine Java-Themen 3
Zrebna Wieso sollte man Null-Prüfungen nicht mit Optional-Objekten nutzen? Allgemeine Java-Themen 13
kodela Textfeld nicht rechteckig Allgemeine Java-Themen 10
G Doppelklick auf Javaprogramm klapt nicht Allgemeine Java-Themen 1
W Timer terminiert nicht Allgemeine Java-Themen 5
D Linux, Java-Version wird nicht erkannt bzw. welche Einstellung fehlt noch? Allgemeine Java-Themen 19
W Überflüssige Deklaration vermeiden...war da nicht mal was? Allgemeine Java-Themen 3
N lwjgl kann textureSampler nicht finden Allgemeine Java-Themen 4
P Fehler: Hauptklasse Main konnte nicht gefunden oder geladen werden Ursache: java.lang.ClassNotFoundException: Main Allgemeine Java-Themen 24
S Java Programm lässt sich vom USB-Stick starten, aber nicht von HDD Allgemeine Java-Themen 16
T .Jar kann man nicht ausführen Allgemeine Java-Themen 18
P JDK nicht installiert in Net Object Fusion Allgemeine Java-Themen 7
D Image bewegt sich nicht nach Klicken auf Button Allgemeine Java-Themen 15
N Regex schlägt nicht an Allgemeine Java-Themen 10
Y Wieso krieg ich die Unit Tests nicht hin Allgemeine Java-Themen 55
D Erste Schritte Mp3 Datei kann nicht von der Festplatte geöffnet werden - mit ChatGPT erstellt Allgemeine Java-Themen 7
G Popup wird nicht sichtbar Allgemeine Java-Themen 9
8u3631984 Funktions Parameter mit Lombok "NonNull" annotieren wird in Jacococ Testcoverage nicht herausgefiltert Allgemeine Java-Themen 3
kodela String kann nicht zu Pfad konvertiert werden Allgemeine Java-Themen 16
M Apache Proxy Weiterleitung auf Tomcat funktioniert nicht wie gewünscht Allgemeine Java-Themen 1
Momo16 Brauche Hilfe - Java Projekt kann nicht erstellt werden Allgemeine Java-Themen 12
OnDemand ApacheCommon FTP Client zuckt nicht Allgemeine Java-Themen 3
T JavaPoet - (noch) nicht existente Typen Allgemeine Java-Themen 2
E Es ist nicht möglich, eine Batch-Anweisung auszuführen. Allgemeine Java-Themen 9
C Was passt hier nicht bei der Calendar-Class Allgemeine Java-Themen 2
T Testing JUnit5: try ... catch arbeitet nicht sauber Allgemeine Java-Themen 6
W While Schleife funktioniert nicht ganz Allgemeine Java-Themen 4
OnDemand MemoryLeak nicht zu finden Allgemeine Java-Themen 26
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
H do-while Schleife funktioniert nicht wie ich es möchte Allgemeine Java-Themen 7
ERlK JDA Code funktioniert nicht? Allgemeine Java-Themen 4
OnDemand Ram Freigabe erfolgt nicht nach Prozessende Allgemeine Java-Themen 18
OnDemand XML desializing Attribute bringt nicht erwartetes Ergebnis Allgemeine Java-Themen 16
T ImageIcon wird nicht angezeigt Allgemeine Java-Themen 6
N JAVA-Code mit Grafikfenster zeichnet in Windows, aber nicht Mac. Allgemeine Java-Themen 4
stormyark TikTakToe funktioniert nicht Allgemeine Java-Themen 10
N Warum wird die For Schleife nicht betreten Allgemeine Java-Themen 4
Tiago1234 Hauptklasse konnte nicht gefunden oder geladen werden Allgemeine Java-Themen 38
T Remove bei ArrayList funktioniert nicht Allgemeine Java-Themen 2
M Map<String,String>funktioniert nicht richtig Allgemeine Java-Themen 4
I "Neues" Lizenzmodell Oracle - JRE nicht mehr zur Redistribution freigegeben? Allgemeine Java-Themen 16
J c Programm läuft nicht in compilierter Version des Java Projektes Allgemeine Java-Themen 7
A code wird nicht ausgeführt Allgemeine Java-Themen 3
Blender3D Alte Beiträge nicht mehr vorhanden Allgemeine Java-Themen 6
M Warum hat Java dieses und jenes nicht... Allgemeine Java-Themen 8
W Bilder werden in App mit Jar-Datei nicht angezeigt Allgemeine Java-Themen 15
Micha43 Applet *.jar läuft nicht auf dem Mac Allgemeine Java-Themen 8
M Warum bekommen ich den Result nicht ? Allgemeine Java-Themen 17
Kiki01 Häufigster Buchstabe lässt sich nicht ermitteln Allgemeine Java-Themen 30
OnDemand RegEx /compilebekomme nicht die erwarteten Werte Allgemeine Java-Themen 9
HerrBolte Seltsamer Fehler nur in der Windows- und nicht in der Java-Console O_O Allgemeine Java-Themen 16
P String.replace() funktioniert nicht? Allgemeine Java-Themen 3
N nicht einsehbarer Fehler im code, kann nicht mehr übersetzten Allgemeine Java-Themen 51
P Karate API Test läuft nicht durch . initializationError Allgemeine Java-Themen 21
N nicht static und auch nicht new Allgemeine Java-Themen 3
Z macOS java konnte nicht entfernt werden xpc verbindungsfehler Allgemeine Java-Themen 4
T Schaltfläche wird nicht gefunden Allgemeine Java-Themen 4
boschl2000 Springerproblem-Implementierung funktioniert nicht richtig Allgemeine Java-Themen 1
F Getter Methode aufrufen funktioniert nicht Allgemeine Java-Themen 1
N Gierigen Regex in nicht-gierigen umwandeln Allgemeine Java-Themen 4
N Regulärer Ausdruck funktioniert nicht Allgemeine Java-Themen 6
AleXusher Hauptklasse startlösung konnte nicht gefunden oder geladen werden Allgemeine Java-Themen 1
G @PostConstruct Annotation nicht mehr gültig ? Allgemeine Java-Themen 7
L Objekte in Set nicht gefunden Allgemeine Java-Themen 13
T Projekt baut nicht mehr/lässt sich nicht mehr ausführen Allgemeine Java-Themen 6
izoards log4j2 will nicht.... Allgemeine Java-Themen 15
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
1Raini Java if-Abfrage funktioniert nicht! Allgemeine Java-Themen 3
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
I serialVersionUID - explizit vergeben oder nicht? Allgemeine Java-Themen 6
MiMa Vorhandenes das nicht existiert?? Allgemeine Java-Themen 7
LimDul Hä? Lambda-Ausdruck geht, Methoden-Referenz nicht Allgemeine Java-Themen 8
O Jar lässt sich auf bestimmten Pc nicht starten Allgemeine Java-Themen 18
T Fremde Typen mockt man nicht? Allgemeine Java-Themen 3
Killunox MaxHeap Zuweisung unter Linux funktioniert nicht Allgemeine Java-Themen 1
LimDul Direktes return eines Array geht nicht Allgemeine Java-Themen 20
B neuroph hält beim XOR lernen nicht an Allgemeine Java-Themen 13
kodela JDialog zeigt Text nicht an Allgemeine Java-Themen 5
Dann07 Java-Programm findet DLLs nicht! Allgemeine Java-Themen 20
D Twitch API mit HttpURLConnection läuft nicht? Allgemeine Java-Themen 0
M Test geht auf Travis und mit Github Action schief aber nicht lokal Allgemeine Java-Themen 3
R Threads Clip loop loopt nicht Allgemeine Java-Themen 2
Dann07 MP3 Datei abspielen funktioniert nicht Allgemeine Java-Themen 6
W Server-Thread schreibt nicht alle Dateien Allgemeine Java-Themen 6
OnDemand JMS Messages nicht abgeholt Allgemeine Java-Themen 0
O Aus JAR-Datei erstellte EXE-Datei funktioniert nicht Allgemeine Java-Themen 10
A Mp3 Player funktioniert nicht Allgemeine Java-Themen 0
W String -> byte[] -> String - Sieht jemand was ich nicht sehe? Allgemeine Java-Themen 10
M Console geht nicht auf (Windows 10) Allgemeine Java-Themen 3
J Hilfe, Jar Datei kann nicht ausgeführt werden Allgemeine Java-Themen 2

Ähnliche Java Themen

Neue Themen


Oben