Eure Wunschliste für Java 7?

Status
Nicht offen für weitere Antworten.

didjitalist

Bekanntes Mitglied
Ich finde das Konzept der checked exceptions gut, nur ist die Umsetzung in den meisten Fällen schlecht. Warum z.B. schmeissen ausnahmslos alle Datenbank APIs checked exceptions, wenn irgendwas mit der Verbindung nicht stimmt? Solche exceptions treten im normalen Programmablauf so gut wie nie auf. Ausnahmen, die aller Wahrscheinlichkeit nach normalerweise nicht auftreten, sollten auch keine checked exceptions schmeissen.

Erst sobald eine Methode eine sehr hohe Wahrscheinlichkeit besitzt, eine exception zu schmeissen, sollte dies eine checked exception sein. Als Beispiel können da Methoden wie Integer#parseInt herhalten.
 

didjitalist

Bekanntes Mitglied
Es geht hier nicht um die Begrifflichkeit "Ausnahme". Es geht um die Unterscheidung zwischen checked und unchecked exceptions.

Ich sehe wenig Sinn im inflationären Gebrauch von checked exceptions. Das verleitet lediglich dazu, genau die exceptions, die fatal sein können, geflissentlich zu ignorieren. Warum denn setzt sogar eine recht gebräuchliche IDE wie eclipse als Standardpattern für automatisch generierten Code das unglaublich sinnfreie "e.printStackTrace()" ein? Ich hab schon verdammt viel Code gesehen, der checked exceptions immer weiter und weiterreicht, bis sie irgendwann irgendwo im GUI verschluckt werden, weil irgendwer "mal eben" was umsetzen und sich zu dem Zeitpunkt keine Gedanken über sinnvolle Fehlerbehandlung mehr machen wollte.
 

AlArenal

Top Contributor
Gegen verhunzten Code helfen keine Featuritis, denn schlechten Stil kann man nicht "Par Ordre De Mufti" unterbinden. Vorhandene Möglichkeiten sinnvoll einzusetzen ist numal Aufgabe des Programmierers und der kann sich nciht darauf berufen, dass ihn die Sprache verleitet hätte, obwohl er es auch hätte besser machen können.

Nachträglich Features entfernen ist erfahrungsgemäß nichts, was man von Sun zu erwarten hat.
 

byte

Top Contributor
Das Konzept ist imo ok, aber es fehlt eine Möglichkeit, ohne Code Bloat alle checked Exceptions zu fangen.
 
S

SlaterB

Gast
> Warum denn setzt sogar eine recht gebräuchliche IDE wie eclipse als Standardpattern für automatisch generierten Code das unglaublich sinnfreie "e.printStackTrace()" ein?

auch hier wieder mahnende Gegenworte:
was anderes geht gar nicht, das ist schon eine sehr löbliche Sache,

wenn man von Eclipse Operationen mit Rückgaberwer generieren lässt,
dann wird da 'return null' reingeschrieben,
auch wenig sinnvoll aber Eclipse kann sich nun wirklich keinen intelligenten Code ausdenken

wenn Eclipse standarmäßig
throw new RuntimeException(e);
schreiben würde, ja dann wäre die Einstellung der Eclipseprogrammierer deutlich :bae:
 

tfa

Top Contributor
byto hat gesagt.:
Das Konzept ist imo ok
Wenn es nichtmal die Java-Schöpfer vernünftig verwenden (siehe viele checked Exceptions bei Reflection, SQLException), was kann man von normalen Entwicklern erwarten?
Checked Exceptions könnten vielleicht bei der Anwendungsentwicklung sinnvoll sein (wenn man wirklich weiß, dass eine Ausnahmesituation behandelt werden kann und muss), aber nicht in allgemein verwendbaren APIs oder Frameworks.
 
S

SlaterB

Gast
andererseits erziehen Checked Exceptions zur Kapselung,

ich finde es immer ganz schrecklich, wenn Framework-Operationen im Programm verteilt sind,
z.B. Hibernate query.list() oder transaction.commit(),

da das ein Einzeiler ist, steht das in meinem Projekt bei jeder von hunderten DB-Operationen einzeln,
und wenn ich nun die Querys zählen, loggen, gar auf Exceptions reagieren will?

wäre diese wichtige Operation ein 10 Zeilen-Code mit try/ catch,
dann wäre sie hoffentlich schon viel eher in eine Wrapper-Operation gewandert die von hunderten Stellen im Programm aufgerufen wird,

das ist kein direkter Zusammenhang mit Checked Exceptions, schließlich gibts auch genug Operationen ganz ohne Exceptions, die man evtl. wrappen möchte,

aber wenn eine Operation eines Framework Exceptions wirft,
dann braucht man die in einem strukturierten Programm nur genau einmal abzufangen,
dieser Aufwand ist nicht allzu hoch
 

byte

Top Contributor
Das hat nun aber wirklich nichts mit dem Exception-Konzept zu tun sondern vielmehr mehr mit dem Design Deiner Anwendung. Oben aufgezählte Hibernate-Methoden werfen alle eine HibernateException, aber die ist halt Unchecked. Die kannst Du genauso fangen wie eine checked Exception, musst es aber nicht.
Du musst hier überlegen, wie Du Deine Persistenzschicht strukturierst - ob checked oder unchecked Exceptions fliegen ist dabei doch egal.

Warum sollte man ein try { query.list } catch(Exception e) { /* Exception Handling */ } eher wegkapseln? Jemand, der weiss was er tut, wird sich eh eine Persistenzschicht mit DAOs hochziehen. Und wer nicht weiss was er tut, der wird auch hier nichts vernünftig kapseln.
 
S

SlaterB

Gast
> Warum sollte man ein try { query.list } catch(Exception e) { /* Exception Handling */ } eher wegkapseln?

aufgrund der Code-Länge, wie gesagt,
wenn du das nicht so siehst ist das ja ok, aber brauchst nicht nochmal warum fragen ;)
 

Generic1

Top Contributor
Ich hab jetzt auch einen Wunsch,
Das Drucken in Java sollte so schnell als möglich überarbeitet werden, da keine Modifikationen an den PrintFrames (Seite einrichten und drucken) möglich sind, das aber manchmal sinn macht,

lg
 

DEvent

Bekanntes Mitglied
SlaterB hat gesagt.:
> Warum sollte man ein try { query.list } catch(Exception e) { /* Exception Handling */ } eher wegkapseln?

aufgrund der Code-Länge, wie gesagt,
wenn du das nicht so siehst ist das ja ok, aber brauchst nicht nochmal warum fragen ;)

Ich wuerde eher sagen wegen vermeidung von Code-Duplication. Im uebrigem neigen checked-Exceptions sowieso zu code-duplication.

Was spricht eigentlich fuer checked-Exceptions? Doch nur das man sie fangen muss. Aber was der Programmierer damit macht, steht nirgens. Wenn Eclipse nicht immer ein // TODO hinzufuegen wuerde, dann wuerden die gefangenen checked Exceptions noch schneller in Vergessenheit geraten.

Frueher habe ich mir keine Gedanken gemacht um checked/unchecked Excepions, aber je laenger ich darueber nachdenke desto mehr komme ich zu dem Schluss, dass sie eine ganz schlechte Idee sind. In der Theorie hoert sich das ganz gut an: Wie zwingen die Programmierer mit checked Exceptions zur richtiger Fehler-Behandlung. In der Praxis zeigt sich aber die wahre Natur eines jeden Programmierer: Die Faulheit.

Ohne checked Exceptions ist die Faulheit kein Problem: Wenn der Programmierer zu faul zur richtigen Fehler-Behandlung war, dann beendet sich das Programm wenn eine Exception fliegt. Mit checked Exeptions laeuft das Programm weiter in einem undefinierten Zustand.
 
S

SlaterB

Gast
> Ich wuerde eher sagen wegen vermeidung von Code-Duplication. Im uebrigem neigen checked-Exceptions sowieso zu code-duplication.

klar Code-Duplication, wenns nicht der gleiche Code wäre, dann könnte man ihn ja nicht in eine Operation zusammenfassen,
Code-Duplication == Code-Länge

-----

ein guter Vergleich zwischen Checked und Unchecked ist auch ein Interface vs Adapter/ Basisklasse,
bei ersterem fängt man ganz bei null an und muss alles behandeln,
bei zweiterem verläßt man sich auf den Default, muss eigentlich nix machen sondern überschreibt nur (fängt nur ab), was aktuell nötig ist

das passt auch zum Kapselungs-Konzept,
wenns keinen WindowAdapter gäbe, dann müsste man ihn sich wirklich selber schreiben bei derart vielen Operationen die man oft nicht braucht ;)
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
W JNI JNA JNR - eure Erfahrungen, Empfehlungen? Allgemeine Java-Themen 3
J Java "Bank Programm" Brauche eure Hilfe Allgemeine Java-Themen 3
S Primzahl || Primfaktorzerlegung -> Eure Laufzeiten *Wen es halt interessiert* Allgemeine Java-Themen 10
R Welche waren eure ersten Projekte? Allgemeine Java-Themen 10
J Eure Meinung: Threads verwenden, oder nicht? Allgemeine Java-Themen 6
E Eure erstellten Programme Allgemeine Java-Themen 3
André Uhres Welches Werzkeug benutzt ihr um eure Mails zu lesen? Allgemeine Java-Themen 47
F (Wie) sortiert ihr eure Felder, Methoden, etc? Allgemeine Java-Themen 19
J Eure Meinung - Das JMF (Java Media Framework) Allgemeine Java-Themen 3
K Design: Klassen in Pakete aufteilen - Eure Meinung Allgemeine Java-Themen 8
L Softwarepatente - Eure Meinung Allgemeine Java-Themen 4
Oneixee5 Für die RPi-Bastler ... Allgemeine Java-Themen 0
I PDF2Tiff für Fax Allgemeine Java-Themen 0
W Vergleichstool für xml-Dateien Tortoise-svn Verknüpfung Allgemeine Java-Themen 2
Zrebna Tipps für Organisation von Code-Reviews nach einem Pull Request. Allgemeine Java-Themen 5
Zrebna Bitte um Empfehlungen für "zeitlose" Bücher bzgl. Backend mit Spring und Beans Allgemeine Java-Themen 25
G Lesbare args für die main-Methode Allgemeine Java-Themen 6
B Algorithmus für Arbeit mit fehlenden Listenelementen? Allgemeine Java-Themen 1
kodela Eingabe für TextArray bedingt sperren Allgemeine Java-Themen 3
Karl_Der_Nette_Anfänger Hat wer ne Lösung für verknüpfte Postleitzahlen? (Baum/Wurzel Struktur) Allgemeine Java-Themen 11
R 11 GB File lesen ohne zu extrahieren Filedaten Bereich für Bereich adressieren dann mit Multi-Thread id die DB importieren Allgemeine Java-Themen 3
G KeyListener für JTextField Allgemeine Java-Themen 5
webracer999 Library für Textsuche (z. B. include/exclude, and/or)? Allgemeine Java-Themen 5
I Module-Info für Jar erzeugen Allgemeine Java-Themen 7
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
B Simpler Eventlistener für Tastaturtaste bauen? Allgemeine Java-Themen 13
G Eingegebenen Text Zeile für Zeile ausgeben lassen Allgemeine Java-Themen 11
E Key für TOTP Algorythmus(Google Authentificator) Allgemeine Java-Themen 0
S Formel für Sonnenwinkel in ein Programm überführen Allgemeine Java-Themen 11
M pfx-Zertifikat in Tomcat für SSL-Verschlüsselung nutzen Allgemeine Java-Themen 14
R Best Practice Erfahrungswerte für eine Migration von JSF nach Angular (oder anderes JS-Framework) Allgemeine Java-Themen 1
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
jhCDtGVjcZGcfzug Klassen Was genau passiert hier? Kann mir das jemand bitte Zeile für Zeile erklären? Allgemeine Java-Themen 1
rosima26 Bester Sortieralgorithmus für kurze Arrays Allgemeine Java-Themen 40
S Mit Methoden kann man definieren für was <T> steht. Geht das auch irgendwie für Variablen? Allgemeine Java-Themen 12
MangoTango Operatoren while-Schleife für Potenz Allgemeine Java-Themen 3
B Lottospiel, genug Reihen tippen für 3 Richtige (Spaß mit Arrays)? Allgemeine Java-Themen 46
B Mit welchen Datentypen und Strukturierung am Besten dutzende Baccaratspiele Shcritt für Schritt durchsimulieren? Allgemeine Java-Themen 26
D Klassendesign für einen Pascal Interpreter Allgemeine Java-Themen 6
I OCR Library für Belegerkennung Allgemeine Java-Themen 7
farah GetterMathod für Farbkanäle Allgemeine Java-Themen 6
B Welcher Datentyp für sehr große Zahlenbereiche? Allgemeine Java-Themen 1
S Webservices für binäre Daten? Allgemeine Java-Themen 5
G Licence-Header für InHouse entwickelten Source Allgemeine Java-Themen 8
M Schleife für einen TicTacToe Computer Allgemeine Java-Themen 5
O git ignore für Intellji braucht es die .idea Dateien? Allgemeine Java-Themen 8
F Java Script für das Vorhaben das richtige? Allgemeine Java-Themen 9
M wiviel Java muss ich für die Berufswelt können ? Allgemeine Java-Themen 5
Robertop Datumsformat für GB ab Java 16 Allgemeine Java-Themen 1
Thallius Verschiedene entities für gleichen Code…. Allgemeine Java-Themen 8
OnDemand Zentrale "Drehscheibe" für verschiedene APIs Allgemeine Java-Themen 14
S Übergabe eines Sortierkriteriums für ein Artikel Array mittels BiPredicate<Artikel, Artikel> Allgemeine Java-Themen 13
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
D SHA-3 für Java-version 1.8 Allgemeine Java-Themen 1
N Validator für einen SQL-Befehl Allgemeine Java-Themen 22
Muatasem Hammud Erstellung von Testdaten für Arrays Allgemeine Java-Themen 6
B Logikfehlersuche, das perfekte Lottosystem für 3 Richtige mit Arraylists? Allgemeine Java-Themen 71
G Methoden für die Zukunft sinnvoll? Allgemeine Java-Themen 4
M API für PLZ Umkreissuche Allgemeine Java-Themen 3
1Spinne JDK 8 für Eclipse installieren Allgemeine Java-Themen 5
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
L Methoden Parser für gängige Datumsformate? Allgemeine Java-Themen 1
H Interface PluginSystem ClassNotFound exception für library Klassen Allgemeine Java-Themen 10
N relativier Pfad für sqlite-Datenbank in Gradle/IntelliJ Allgemeine Java-Themen 2
buchfrau Anagram für beliebiges Wort Allgemeine Java-Themen 2
TonioTec Api für Datenaustausch zwischen Client und Server Allgemeine Java-Themen 0
W Suche Ursache für NPE - woher kommt sie? (Hilfe beim Debugging) Allgemeine Java-Themen 19
Kirby.exe Distanz Map für die Distanztransformation erstellen Allgemeine Java-Themen 1
F PI Regler für Heizung Allgemeine Java-Themen 7
8u3631984 Generelle Log4j.xml für alle Module Allgemeine Java-Themen 5
M Wie übergebe ich den Zähler für die Anzahl Rekursionsschritte korrekt? Allgemeine Java-Themen 2
B Login für User, der im Hintergrund Schedules ausführt Allgemeine Java-Themen 16
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
S Java-Task-Management-Tool für Windows und Mac selber programmieren Allgemeine Java-Themen 4
M Java 2D Array für ein Grid erstellen ? Allgemeine Java-Themen 2
Z Welches GUI Framework für Java ist aktuell? Allgemeine Java-Themen 16
N Convert.FromBase64 von C# für Java Allgemeine Java-Themen 11
N fixed-keyword von C# für Java Allgemeine Java-Themen 6
O Suche Scripter für alt:V Project! Allgemeine Java-Themen 0
S Interface Design von HookUp oder Callback Methoden für eigenes Framework Allgemeine Java-Themen 9
O Suche Unterstützung für ein OpenSource-Projekt (grafischer Editor) Allgemeine Java-Themen 13
Kirby.exe Software für Graphische Visualisierung Allgemeine Java-Themen 20
B OOP Auslöser für NullPointerException Allgemeine Java-Themen 3
L Generator für einen Parser implementieren Allgemeine Java-Themen 13
DonMalte Ambitioniertes Projekt für Einsteiger & Motivierte Allgemeine Java-Themen 0
Kirby.exe Movement System für Spiel Allgemeine Java-Themen 13
Kirby.exe Framework für Game Design Allgemeine Java-Themen 8
W Alternative für Threads Allgemeine Java-Themen 6
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
Elyt Compiler-Fehler Datei kann nicht erstellt werden. Die Syntax für den Dateinamen etc. ist falsch. Allgemeine Java-Themen 2
Thallius Rätsel für Windows Profis Allgemeine Java-Themen 8
D OOP Gemeinsamen ID-Raum für zwei Klassen implementieren Allgemeine Java-Themen 7
D Input/Output Implementierung eines CommandHandlers/Parsers für viele Eingaben Allgemeine Java-Themen 26
Thallius Alternative für SwingWorker Allgemeine Java-Themen 5
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Datenstruktur für eine Map erstellen Allgemeine Java-Themen 2
H OOP Setting(config) für Applikation sicheren? Allgemeine Java-Themen 9
OnDemand PDF Libary für Formulare Allgemeine Java-Themen 7
S Warmup für Lineare-Suche mit Zeitmessung Allgemeine Java-Themen 2

Ähnliche Java Themen

Neue Themen


Oben