Fehlerbehandlung (Lernzielkontrolle zu Exceptions) – Anwendungsentwickler-Podcast #79 - podcast episode cover

Fehlerbehandlung (Lernzielkontrolle zu Exceptions) – Anwendungsentwickler-Podcast #79

Oct 10, 201642 min
--:--
--:--
Download Metacast podcast app
Listen to this episode in Metacast mobile app
Don't just listen to podcasts. Learn from them with transcripts, summaries, and chapters for every episode. Skim, search, and bookmark insights. Learn more

Episode description

Eine Lernzielkontrolle zu Exceptions (in Java) gibt es in der neunundsiebzigsten Episode des Anwendungsentwickler-Podcasts.

Inhalt Exceptions
  • Was ist eine „Exception“?
    • Eine unerwartete Ausnahmesituation in einem Programm, meistens ein Fehler.
    • Oder: Die Klasse, die dieses Konzept in der Programmiersprache repräsentiert.
  • Was ist die Analogie zur Erklärung der Behandlung von Exceptions?
    • Man „wirft“ und „fängt“ Exceptions wie einen Ball.
  • Wie kann man grundsätzlich mit Exceptions umgehen?
    • Man kann sie entweder direkt fangen (und das Problem lösen) oder dies an den Aufrufer delegieren (weiterwerfen).
  • Wie behandelt man eine Exception in Java?
    • Mittels try, catch und finally.
  • Wann braucht man einen finally-Block?
    • Wenn eine Operation unter allen Umständen nach try/catch ausgeführt werden muss (insb. wenn im catch-Block potentiell auch Fehler auftreten können).
  • Was ist try-with-resources?
    • Ein Sprachkonstrukt in Java, das dafür sorgt, dass Ressourcen nach ihrer Nutzung sauber wieder geschlossen werden, egal ob eine Exception auftritt oder nicht. Die Ressource muss dafür java.lang.AutoCloseable implementieren. Entspricht using in .NET.
  • Was macht das Schlüsselwort throw?
    • Wirft eine Exception.
  • Was macht das Schlüsselwort throws?
    • Markiert eine Methode als potentiell fehleranfällig und zwingt den Aufrufer zur Fehlerbehandlung.
  • Was ist der Unterschied zwischen „checked“ und „unchecked“ Exceptions?
    • Checked Exceptions (die es nur in Java gibt), müssen behandelt werden (der Compiler prüft das). Unchecked Exceptions (z.B. nicht vorhersehbare Laufzeitfehler wie „Speicher voll“) müssen nicht behandelt werden.
  • Wie erzeugt man seine eigenen Exceptions?
    • Man kann eigene Klassen von Exception erben lassen. Diese können dann auch „echte“ Attribute und Methoden beinhalten.
  • Was ist der „Call Stack“?
    • Der Aufrufstack enthält die Rücksprungadressen aller im bisherigen Programmablauf aufgerufenen Methoden. Darüber kann man nachvollziehen, wie das Programm zur aktuellen Position gelangt ist. Jede Exception hat den Call Stack bis zu ihrem Auftreten als Attribut.
  • Sollte man Exceptions zur Steuerung des Programmablaufs einsetzen?
    • Nein, da Exceptions – z.B. wegen des Call Stacks – recht „teuer“ sind.
  • Wie sieht die Hierarchie von Exceptions in Java grob aus?
  • Was sind die Vorteile von Exceptions gegenüber direkter Fehlerbehandlung?
    • Produktivcode und Fehlerbehandlungscode werden stärker getrennt.
    • Man kann das Behandeln von Fehlern an den Aufrufer delegieren.
    • Man kann einfacher zwischen verschiedenen Fehlern unterscheiden.
Literaturempfehlungen Links
For the best experience, listen in Metacast app for iOS or Android