Objektorientierte Programmierung: Unterschied zwischen den Versionen
Drlue (Diskussion | Beiträge) |
Drlue (Diskussion | Beiträge) |
||
| Zeile 1: | Zeile 1: | ||
== Exceptions == | == Exceptions == | ||
'''Exceptions''' oder '''Ausnahmen''' können von {{Link|Methoden}} geworfen werden. Eine '''Exception''' tritt auf, wenn eine Methode außerhalb ihrer gewünschten Funktionalität operiert. Jede '''Exception''' ist ein {{JSL|java.lang.Throwable}}, d.h. entweder ist es die direkte '''Superklasse''', oder irgendwo weiter oben. | '''Exceptions''' oder '''Ausnahmen''' können von {{Link|Methoden}} geworfen werden. Eine '''Exception''' tritt auf, wenn eine Methode außerhalb ihrer gewünschten Funktionalität operiert. Jede '''Exception''' ist ein {{JSL|java.lang.Throwable}}, d.h. entweder ist es die direkte '''Superklasse''', oder irgendwo weiter oben. Weiters unterscheiden wir zwei Arten von '''Exceptions'''. | ||
Weiters unterscheiden wir zwei Arten von '''Exceptions'''. | |||
=== Checked Exceptions === | === Checked Exceptions === | ||
Dazu gehört jede '''Exception''' die von {{JSL|java.lang.Throwable}} erbt, aber keine {{JSL|java.lang.RuntimeException}} und kein {{JSL|java.lang.Error}} ist. Wenn '''Checked Exceptions''' geworfen werden, so muss dies in der Methode mittels {{JSL|throws ExceptionName}} deklariert werden. Zusätzlich muss diese Art von Exeptions auch immer von der Aufrufenden {{Link|Methoden|Methode}} behandelt, oder weitergeworfen werden. | Dazu gehört jede '''Exception''' die von {{JSL|java.lang.Throwable}} erbt, aber keine {{JSL|java.lang.RuntimeException}} und kein {{JSL|java.lang.Error}} ist. Wenn '''Checked Exceptions''' geworfen werden, so muss dies in der Methode mittels {{JSL|throws ExceptionName}} deklariert werden. Zusätzlich muss diese Art von Exeptions auch immer von der Aufrufenden {{Link|Methoden|Methode}} behandelt, oder weitergeworfen werden. | ||
Version vom 27. Januar 2021, 16:17 Uhr
Exceptions
Exceptions oder Ausnahmen können von Methoden geworfen werden. Eine Exception tritt auf, wenn eine Methode außerhalb ihrer gewünschten Funktionalität operiert. Jede Exception ist ein java.lang.Throwable, d.h. entweder ist es die direkte Superklasse, oder irgendwo weiter oben. Weiters unterscheiden wir zwei Arten von Exceptions.
Checked Exceptions
Dazu gehört jede Exception die von java.lang.Throwable erbt, aber keine java.lang.RuntimeException und kein java.lang.Error ist. Wenn Checked Exceptions geworfen werden, so muss dies in der Methode mittels throws ExceptionName deklariert werden. Zusätzlich muss diese Art von Exeptions auch immer von der Aufrufenden Methode behandelt, oder weitergeworfen werden.
Unchecked Exceptions
Dazu gehören Alle Exceptions welche von java.lang.Error oder von java.lang.RuntimeException erben. Diese Exceptions müssen nicht in der Methoden Definition deklariert werden. Sie können abgefangen werden, normalerweise sollten diese aber überhaupt nicht auftreten.
| Klasse | Code |
|---|---|
java.lang.IndexOutOfBoundsException |
int[] arr = new int[]{1,2,3,4};
System.out.println(arr[5]);
|
java.lang.NullPointerException |
Animal a = null;
System.out.println(a.toString());
|
| Klasse | Code |
|---|---|
java.lang.OutOfMemoryError |
//Tritt auf wenn keine weiteren neuen Objekte mehr erstellt werden können
List<String> list = new LinkedList<>();
while(true) {
list.add("Hallo");
}
|
java.lang.NullPointerException |
Animal a = null;
System.out.println(a.toString());
|
Beispiele
Im folgenden Beispiel wird eine Methode erstellt, welche einen Dateinamen nimmt und die Länge der Datei zurückgibt. Existiert die Datei nicht, so wird eine java.lang.FileNotFoundException geworfen:
public static long getFileLength(String fileName) throws FileNotFoundException {
File f = new File(fileName);
if(!f.exists()) {
throw new FileNotFoundException();
}
return f.length();
}