Objektorientierte Programmierung: Unterschied zwischen den Versionen
Drlue (Diskussion | Beiträge) |
Drlue (Diskussion | Beiträge) |
||
| Zeile 14: | Zeile 14: | ||
{{JML|code= | {{JML|code= | ||
int[] arr = new int[]{1,2,3,4}; | int[] arr = new int[]{1,2,3,4}; | ||
//Index existiert nicht | |||
System.out.println(arr[5]); | System.out.println(arr[5]); | ||
}} | }} | ||
| Zeile 20: | Zeile 21: | ||
{{JML|code= | {{JML|code= | ||
Animal a = null; | Animal a = null; | ||
//Die Referenz ist null, beim Zugriff crashts | |||
System.out.println(a.toString()); | System.out.println(a.toString()); | ||
}} | }} | ||
| Zeile 35: | Zeile 37: | ||
list.add(new int[10000]); | list.add(new int[10000]); | ||
} | } | ||
}} | }} | ||
|} | |} | ||
Version vom 27. Januar 2021, 16:20 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};
//Index existiert nicht
System.out.println(arr[5]);
|
java.lang.NullPointerException |
Animal a = null;
//Die Referenz ist null, beim Zugriff crashts
System.out.println(a.toString());
|
| Klasse | Code |
|---|---|
java.lang.OutOfMemoryError |
//Tritt auf wenn keine weiteren neuen Objekte mehr erstellt werden können
List<int[]> list = new LinkedList<>();
while(true) {
list.add(new int[10000]);
}
|
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();
}