Frage zu Try - Catch - Finally

Status
Nicht offen für weitere Antworten.

Ishildur

Bekanntes Mitglied
Hallo zusammen
Irgendwie ist mir der Sinn und Zweck des Schlüsselwortes "finally" nicht so ganz klar. In den Dokus kann ich nachlesen, dass ein finally dazu verwendet wird, um Resource wieder freizugeben, selbst wenn eine Exception ausgelöst wird. Aber wieso brauche ich denn hierfür nun Konkret ein finally?

Code:
// allocate some resources

try{
 // do some dangerous code
}
catch(Exception exp){
 // handle all errors
}
finally{
 // free all resources
}

Aber wieso kann ich das nicht auch genausogut so machen?

Code:
try{
 // do some dangerous code
}
catch(Exception exp){
 // handle all errors
}

 // free all resources

Hmm, ich kapiers nicht...

Ishildur
 

Lim_Dul

Top Contributor
Was ist wenn im Exception Block eine neue Exception fliegt?
Was ist, wenn eine RuntimeException fliegt, die nicht im Catch-Block steht?
Was ist mit return-Statements im Code?
Was ist, wenn du eine Exception nach oben durchreichen willst?
 

ARadauer

Top Contributor
kurz: der finally block wird immer ausgeführt, auch wenn du vorher aus irgendwelchen gründen die methode verlässt
 

FArt

Top Contributor
Beispiel (Pflichtprogramm)
Wenn du mit Streams arbeitest, dann werden die in einme finally-Block geschlossen... heißt auf deutsch: komme was wolle, der Stream ist zu.
 

Landei

Top Contributor
kurz: der finally block wird immer ausgeführt, auch wenn du vorher aus irgendwelchen gründen die methode verlässt

Wenn du mit Streams arbeitest, dann werden die in einme finally-Block geschlossen... heißt auf deutsch: komme was wolle, der Stream ist zu.

falsch und falsch

Code:
public class Finally {
  public static void main(String... args) {
    try {
      System.exit(0);
    } finally {
      System.out.println("Elvis was here");
    }
  }
}
 

ARadauer

Top Contributor
also der stream ist deiner meinung nach noch offen, wenn das programm geschlossen wurde?

mhn... kann sein
 

Oli

Top Contributor
Hallo Landei,

Naja, System.exit(0), schießt natürlich alles ab.
Das was ARadauer und FArt gesagt haben stimmt natürlich schon.

Dein Beispiel wäre vergleichbar mit einer USV, die umschalten soll wenn ein Stromausfall da ist, aber vorher reiß ich den Akku raus!

try - versucht etwas auszuführen
catch - wird ausgeführt wenn es in der try zu einer Exception kommt
finally - wird immer ausgeführt (eben abschließend)


Grüße Oli.


edit: Der Stream ist nach einem System.exit() auch zu, weil meines Wissen System.exit() alles was von der Applikation referenziert wurde, gnadenlos killt... Da kann ich mich aber täuschen und bin für Aufklärung diesbezüglich offen.
 

Landei

Top Contributor
Streams haben i. d. R. als "Sicherheitsnetz" ein close() in ihrer finalize()-Methode.

Worauf ich eigentlich hinaus will:
- Es gibt eben doch Situationen, in denen finally nicht aufgerufen wird (es gibt dafür wohl auch andere Möglichkeiten als System.exit())
- Wenn man im try-finally Block fremden Code ausführt, kann man mächtig auf die Nase fallen
- System.exit() ist böse. Eigentlich gehört es deprecated, aber dann brauchte man eine andere Möglichkeit, der Applikation einen Exit-Wert mitzugeben.

Übrigens ist das nicht die einzige Falle, in die man bei finally tapsen kann. Zieht euch mal diese "Perle" der Programmierkunst rein:
Code:
public static int test() {
  for (; ; ) {
    try {
      return 1;
    } finally {
      break;
    }
  }
  return -1;
}
 

FArt

Top Contributor
Landei hat gesagt.:
Streams haben i. d. R. als "Sicherheitsnetz" ein close() in ihrer finalize()-Methode.

Worauf ich eigentlich hinaus will:
- Es gibt eben doch Situationen, in denen finally nicht aufgerufen wird (es gibt dafür wohl auch andere Möglichkeiten als System.exit())
- Wenn man im try-finally Block fremden Code ausführt, kann man mächtig auf die Nase fallen
- System.exit() ist böse. Eigentlich gehört es deprecated, aber dann brauchte man eine andere Möglichkeit, der Applikation einen Exit-Wert mitzugeben.

Übrigens ist das nicht die einzige Falle, in die man bei finally tapsen kann. Zieht euch mal diese "Perle" der Programmierkunst rein:
Code:
public static int test() {
  for (; ; ) {
    try {
      return 1;
    } finally {
      break;
    }
  }
  return -1;
}

finally wird immer ausgeführt. System.exit ist ein Ausnahmefall.

Aber man muss aufpassen, was man im finally Block macht. Eine Exception, die nicht verarbeitet wird kann einen sonst gültigen Returnwert oder einen Fehler verdecken, das gleiche gilt für einen "alternativen Return"... das sind schlicht und einfach Programmierfehler.
 

HoaX

Top Contributor
naja, man müsste mal testen ob bei Thread#stop (das eh schon deprecated ist) auch der finally-block ausgeführt wird ... aber sonst fällt mir eigentlich kein fall ein wo man hard in den ablauf eingreift.
 

Oli

Top Contributor
Landei hat gesagt.:
Code:
public static int test() {
  for (; ; ) {
    try {
      return 1;
    } finally {
      break;
    }
  }
  return -1;
}

Da meckert aber der Compiler, dass der finally Block nicht korrelt beendet wird. Nun, bei Warungen sollte man eben mal über den Code schauen, ob da vielleicht was faul ist....
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Frage zum Thema Exceptions (Try/Catch) Java Basics - Anfänger-Themen 3
M Frage zu try ... catch Java Basics - Anfänger-Themen 9
C Frage zu try - catch (saubere Lösung?) Java Basics - Anfänger-Themen 3
C Exceptions, try, catch --> Frage Java Basics - Anfänger-Themen 7
J Try-Catch-Frage Java Basics - Anfänger-Themen 13
D Frage try and catch Java Basics - Anfänger-Themen 7
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

Ähnliche Java Themen

Neue Themen


Oben