![]() |
Delphi-Version: 2007
Parameter-Übergabe: normal, var, const
Hi,
es geht mir um die Übergabe komplexer Variablen (Objekten) in Prozedur-/Funktionsaufrufen. Ich habe folgende Vermutungen, bin aber nicht ganz sicher, ob sie so stimmen. Gehen wir von folgendem Beispielcode aus (TObj sei ein komplexes Objekt):
Delphi-Quellcode:
procedure proc1()
var var1: TObj; begin var1 := TObj.create(); proc2(var1); end; Fall 1:
Delphi-Quellcode:
procedure proc2(a: TObj)
--> Ich kann jetzt etwas am Objekt ändern (
Delphi-Quellcode:
) nicht aber das Objekt komplett austauschen (
a.caption:='aa'
Delphi-Quellcode:
) sodass dies auch Auswirkungen auf proc1 hätte (var1 zeigt immer noch auf das ursprüngle TObj.), da ein Kopie des Objektzeigers bei der Übergabe angelegt wurde.
a:=TObj.create();
Fall 2:
Delphi-Quellcode:
procedure proc2(var a: TObj)
--> Ich kann jetzt sowohl etwas am Objekt ändern (
Delphi-Quellcode:
) wie auch das Objekt komplett austauschen (
a.caption:='aa'
Delphi-Quellcode:
) sodass dies auch Auswirkungen auf proc1 hat (hier wurde also auch var1 "ausgetauscht") - der "Original-Zeiger" wurde also übergeben.
a:=TObj.create();
Fall 3:
Delphi-Quellcode:
procedure proc2(const a: TObj)
--> Ich kann jetzt etwas am Objekt ändern (
Delphi-Quellcode:
) nicht aber das Objekt komplett austauschen (
a.caption:='aa'
Delphi-Quellcode:
) - hier schmeißt mir der Compiler es um die Ohren, da ich versuche, etwas konstantes zu verändern.
a:=TObj.create();
Stimmt das soweit? Falls ja, so ist der Unterschied zwischen Fall 1 und Fall 3 doch recht gering, oder? Zumindest nach "außen" (also aus Sicht von proc1). Kann dazu noch jemand etwas mehr sagen? Dann eine weitere Nachfrage: Auch in Fall 3 ist es ja so, dass ich weiterhin Änderungen am Objekt vornehmen kann, oder? Also const ist lediglich der Zeiger auf das Objekt - nicht aber der "Inhalt" des Objektes selbst - richtig? LG, Frederic |
AW: Parameter-Übergabe: normal, var, const
Ja, stimmt soweit. Und auch in Fall 3 kann man Änderungen am Objekt vornehmen. Das const bezieht sich ja nur auf das Objekt selbst und nicht auf die Eigenschaften des Objektes. Prinzipiell änderst du auch nicht die Eigenschaften des Objektes, sondern du beauftragst das Objekt, die Eigenschaften auf den jeweils gewünschten Wert zu ändern (-> Getter/Setter).
Bernhard |
AW: Parameter-Übergabe: normal, var, const
Hi,
danke für deine Antwort. D.h. der Unterschied zwischen Fall 1 und 3 ist von außen betrachtet nur eine Compiler-Warnung/Compiler-Error - aber am Ergebnis ändert sich sonst nix? LG, Frederic |
AW: Parameter-Übergabe: normal, var, const
Das wirklich fiese an dem ganzen ist dass Free auch zu den Objektmethoden gehört....
Ein FreeAndNil bei var wie erwartet funktioniert, bei Const nicht kompilerbar ist und bei "normaler" Übergabe gegf. unerwartete Seiteneffekte hat. |
AW: Parameter-Übergabe: normal, var, const
Zitat:
Zitat:
|
AW: Parameter-Übergabe: normal, var, const
Beim Fall 1 wird das Objekt By-Value übergeben, das heisst der Wert wird kopiert.
Beim Fall 3 wir das Objekt By-Reference übergeben, das heisst das ein Pointer auf das Objekt übergeben wird. Fall 2 und 3 sind sich sehr ähnlich, mit dem Unterschied dass im Fall 3 dem Parameter nichts zugewiesen werden kann und der Compiler entsprechende Optimierungen vornehmen kann. Im Fall 1 kann man dem Parameter-Objekt einen Wert zuweisen. Diese Zuweisung gilt nur innerhalb der Funktion wo der Parameter deklariert wurde. Im Falle eines Objektes sind die Unterschiede zwischen 1 und 2 nicht so gross, aber das ganze wird vor allem dann interessant wenn man Strings oder Arrays übergibt. Da beim Fall 1 by Value übergeben wird, wird bei jedem Funktionsaufruf der String-Parameter (bzw Array) kopiert, was für die Performance natürlich sub-ideal ist. Im Fall 3 wird nur der Pointer zum String übergeben, was wesentlich schneller geht. |
AW: Parameter-Übergabe: normal, var, const
Zitat:
Aber es ist nicht so. Es wird ebenfalls nur eine Referenz auf den String übergeben und erst wenn man diesen innerhalb der Methode auch ändert wird er on-demand kopiert. Zumindest bei einem eben gemachten, kleinen Test :roll: |
AW: Parameter-Übergabe: normal, var, const
Copy on write? Mag sein, das wusste ich jetzt nicht. Funktioniert das auch mit ausgeschaltete Optimierung?
|
AW: Parameter-Übergabe: normal, var, const
Genau.
Keine Ahnung ... bin jetzt auch zu faul zum testen :P |
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:25 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz