Call by Reference: Unterschied zwischen den Versionen
(→Beispiel) |
(→Beispiel) |
||
Zeile 36: | Zeile 36: | ||
</source> | </source> | ||
− | Hier wird noch | + | Hier wird noch einmal verdeutlicht, dass Variablen mit Objektdatentyp nur '''Referenzen''' auf Objekte speichern. Eine Änderung der von <code>a</code> gespeicherten Referenz in <code>callee</code> (Zeile 10) hat daher wie bei [[Call by Value]] keinen Einfluss auf die aufrufende Funktion <code>caller</code>. |
Aktuelle Version vom 26. September 2016, 17:59 Uhr
Unter Call by Reference versteht man das Übergeben von Objektreferenzen an Methoden.
Eine Variable mit einem Objektdatentyp speichert nicht das Objekt selbst, sondern nur eine Referenz auf dieses Objekt. Wird also eine Objektvariable an eine Methode übergeben, wird nur eine Kopie der Referenz auf ein Objekt übergeben, nicht jedoch eine Kopie des Objektes selbst. Dadurch haben anschließende Änderungen an Attributen des Objektes in der aufgerufenen Methode Einfluss auf die Attribute des Objektes außerhalb der Methode.
Alle Variablen, die dieselbe Referenz besitzen, erfahren dadurch die Änderungen an dem Objekt hinter der Referenz. Dies steht im Kontrast zu Variablen mit primitivem Datentyp. Ihr Wert wird immer direkt übergeben und nicht die Referenz auf den Speicherbereich, in dem der Wert zu finden ist (siehe Call by Value).
Beispiel
public static void caller(){ NumberStorage x = new NumberStorage(5); //Arbiträres Objekt, das eine Zahl mit dem Attribut "value" speichert. System.out.println("x.value: "+x.value); //Gibt aus: "x.value: 5" callee(x); //Übergibt die Referenz von x and callee (Call by Reference) System.out.println("x.value: "+x.value); //Gibt aus: "x.value: 3" } public static void callee(NumberStorage a){ a.value = 3; //Setzt den Wert des übergebenen Objektes auf 3 }
In diesem Beispiel deklarieren wir eine Variable mit dem Namen x
. Diese speichert eine Referenz auf ein NumberStorage
-Objekt. x
wird mit einer Referenz auf ein neues Objekt initialisiert. (Zeile 2) Der in dem Objekt gespeicherte Wert ist 5. Der anschließende Aufruf der Funktion callee
(Zeile 4) hat nun Einfluss auf das übergebene Objekt, da die Referenz darauf übergeben wird. Die Änderung des Wertes dieses Objektes in callee
(Zeile 9) hat daher auch Einfluss auf die Variable x
. Die Variablen a
und x
verweisen nämlich (momentan) auf das gleiche Objekt. Entsprechend ist der Wert des Objektes hinter x
nach Aufruf der Funktion callee
nun 3 anstatt 5 (Zeile 5). Das öffentliche Zugänglichmachen des value
-Attributes ist dabei zugegebenermaßen schlechter Stil.
public static void caller(){ NumberStorage x = new NumberStorage(5); //Arbiträres Objekt, das eine Zahl speichert. System.out.println("x: "+x.value); //Gibt aus: "x: 5" callee(x); //Übergibt die Referenz von x and callee (Call by Reference) System.out.println("x: "+x.value); //Gibt aus: "x: 3" } public static void callee(NumberStorage a){ a.value = 3; //Setzt den Wert des übergebenen Objektes auf 3 a = new NumberStorage(8); //Erzeugt ein neues Objekt und überschreibt die lokale Referenz }
Hier wird noch einmal verdeutlicht, dass Variablen mit Objektdatentyp nur Referenzen auf Objekte speichern. Eine Änderung der von a
gespeicherten Referenz in callee
(Zeile 10) hat daher wie bei Call by Value keinen Einfluss auf die aufrufende Funktion caller
.