![]() |
Forward in Klassen funktioniert nicht
Hallo ich mache da wohl einen Denkfehler und komme nicht drauf
Delphi-Quellcode:
type
// Define the classes in this Unit at the very start for clarity TForm1 = Class; // This is a forward class definition TFruit = Class(TObject) // This is an actual class definition : // Internal class field definitions - only accessible in this unit private t : TForm1; // Warum ist die variable ungültig ! isRound : Boolean; length : single; width : single; diameter : single; // Fields and methods only accessible by this class and descendants procedure SetForm(const Value : TForm1); protected // Externally accessible fields and methods public // 2 constructors - one for round fruit, the other long fruit constructor Create(diameter : single); overload; constructor Create(length : single; width : single); overload; // Externally accessible and inspectable fields and methods published // Note that properties must use different names to local defs property round : Boolean read isRound; property len : single read length; property wide : single read width; property diam : single read diameter; end; // End of the TFruit class definition // The actual TForm1 class is now defined TForm1 = Class(TForm) Button1: TButton; Button2: TButton; procedure FormCreate(Sender: TObject); procedure ShowFruit(fruit : TFruit); procedure Button1Click(Sender: TObject); procedure Button2Click(Sender: TObject); private // No local data f : TFruit; public // Uses just the TForm ancestor class public definitions end; var Form1: TForm1; implementation {$R *.dfm} // Create a round fruit object constructor TFruit.Create(diameter: single); begin // Indicate that we have a round fruit, and set its size isRound := true; self.diameter := diameter; end; // Create a long fruit object constructor TFruit.Create(length, width: single); begin // Indicate that we have a long fruit, and set its size isRound := false; self.length := length; self.width := width; end; procedure TFruit.SetForm(const Value : TForm1); var f1 : TForm1; begin t := nil; // Nicht mal das geht f1 := Value; // Das würde gehen t := Value; // und das ist der Grund für den Eintrag end; // Form object - action taken when the form is created procedure TForm1.Button1Click(Sender: TObject); begin FormCreate(Sender); end; procedure TForm1.Button2Click(Sender: TObject); var Fruit : TFruit; begin Fruit := TFruit.Create(23); ShowFruit(Fruit); end; procedure TForm1.FormCreate(Sender: TObject); var apple, banana : TFruit; begin f.SetForm(self); // Let us create our fruit objects apple := TFruit.Create(3.5); banana := TFruit.Create(7.0, 1.75); // Show details about our fruits ShowFruit(apple); ShowFruit(banana); end; // Show what the characteristics of our fruit are procedure TForm1.ShowFruit(fruit: TFruit); begin if fruit.round then ShowMessage('We have a round fruit, with diam = '+ FloatToStr(fruit.diam)) else begin ShowMessage('We have a long fruit'); ShowMessage(' it has length = '+FloatToStr(fruit.len)); ShowMessage(' it has width = '+FloatToStr(fruit.wide)); end; end; end. ![]() Ich habe das Beispiel ein wenig abgeändert Meine Frage wie kann ich dem Object TFruit mitteilen das TForm1 Object mitteilen. |
AW: Forward in Klassen funktioniert nicht
Welche Meldung kommt?
Das Feld 't' wird nicht verwendet (dem Wert wird nur etwas zugewiesen), vielleicht meckert dein Delphi darüber... |
AW: Forward in Klassen funktioniert nicht
Dein Ansatz ist schon richtig, Du musst nur das Object f erst erzeugen, bevor du darauf zugreifst:
Delphi-Quellcode:
Und du musst dafür sorgen, dass f irgendwo wieder freigegeben wird, am Besten im OnDestroy.
f:=TFruit.Create(0);
f.SetForm(self); |
AW: Forward in Klassen funktioniert nicht
Warum muss TFruit eigendlich etwas von TForm1 wissen? Du greifst in TFruit in keiner Procedure auf TForm1 zu.
OK. Quellcode ggf. nicht komplett. Ich rate mal. Wenn du auf der Form irgend etwas von TFruit anzeigen möchtest, dann konnte die Form das selber übernehmen. Du brauchst nur ein TNotify-Event anlegen. Damit kann TFruit dem TForm1 mitteilen, daß was geändert wurde und Form1 zeichnet selber. P.S.: Ich will nicht etwas gegen Forwarding sagen. Verwende ich selber sehr oft. Kommt aber auf die Situation an. |
AW: Forward in Klassen funktioniert nicht
Das sehe ich ähnlich. Für mich hat Klassenforwarding ein Geschmäckle, denn es wird meist dazu benutzt, Klassen untereinander bekannt zu machen. Das ist zwar nicht in jedem Fall immer einfach zu umgehen, elegant ist das IMO allerdings nicht.
|
AW: Forward in Klassen funktioniert nicht
Zitat:
Class-Forwarding heisst ja nur, "Hallo mich gibt es". |
AW: Forward in Klassen funktioniert nicht
Nur weil im letzten Jahrtausend etwas in der VCL gemacht wurde, heißt das ja noch nicht, dass das auch gut ist.
|
AW: Forward in Klassen funktioniert nicht
Zitat:
Oder wie würdest Du sonst Abhängigkeiten untereinander bekanntmachen? Jetzt nicht speziell für Delphi, sondern auch gerne ganz allgemein. |
AW: Forward in Klassen funktioniert nicht
Zitat:
|
AW: Forward in Klassen funktioniert nicht
Zitat:
Selbst das Leben besteht nur, weil es solche Abhänigkeiten kennt. Da gibt es die Klassen "Sperma", "Eizelle" und "Mensch". Die Klasse "Mensch" sogar in den Unterklassen "Männlich" und "Weiblich". "Mensch" muss entwerder "Sperma" oder "Eizelle" kennen. "Eizelle" muss "Sperma" kennen und umgekehrt, sonst wissen die gar nicht, dass sie zusammenfinden müssen. Haben sie sich gefunden, dann müssen sie aber wiederum die Klasse "Mensch" kennen, den sie zusammen daraus entwickeln wollen. Ich will jetzt erst gar nicht auf die Proceduren der Unterklassen "Männlich" und "Weiblich" eingehen, welche es "Sperma" und "Eizelle" ermöglichen sich zu treffen. |
AW: Forward in Klassen funktioniert nicht
Und alles liegt unter der Klasse Lebewesen.
Sherlock |
AW: Forward in Klassen funktioniert nicht
Zitat:
Das kann nur so sein, da sie aussergewöhnlich viele Fehler enthält. |
AW: Forward in Klassen funktioniert nicht
Zitat:
Zitat:
Man könnte natürlich auch die Form als Owner übergeben und dann über den Owner auf die Form casten. Ansonsten enthalte ich mich erstmal allen Spekulationen und warte auf die Antwort zur Frage. Was heißt "ungültig"? Und gibt es noch weitere Fehlermeldungen? (vonwegen Folgefehler usw.) |
AW: Forward in Klassen funktioniert nicht
Zitat:
Zitat:
In der Softwareentwicklung müssen die Klassen nichts voneinander wissen. Eine Eizelle und ein Mensch können sehr gut existieren, ohne einander zu kennen. Zitat:
Wechselseitige Abhängigkeiten sind dagegen erstens zu vermeiden und zweitens immer vermeidbar. Es reicht ja schon, ein Interface einzuführen. Alternativ dazu kann ich auch mit Events arbeiten. Wechselseitige Abhängigkeiten führen zudem dazu, das die Klasse ihre Allgemeingültigkeit und Wiederverwendbarkeit einschränkt, wenn nicht sogar verliert. |
AW: Forward in Klassen funktioniert nicht
Huch so viele schon
Delphi-Quellcode:
Also wenn // t := nil;procedure TFruit.SetForm(const Value : TForm1); var f1 : TForm1; begin t := nil; // Nicht mal das geht f1 := Value; // Das würde gehen t := Value; // und das ist der Grund für den Eintrag end; dann kann ich das Object mit Value an f1 übergeben nur t in private deklariert das geht gar nicht dann gibt es eine EAccessViolation Schutzverletzung. Ob das elegant ist, ist erst mal egal. Es geht ja auch darum mal was anderes zu probieren und zu lernen. Ich habe die Komponente comport411f eine tolle Freeware Komponente wo das funktioniert und ich verstehe nicht warum das hier nicht funktioniert. |
AW: Forward in Klassen funktioniert nicht
Hast du meinen Hinweis von #3 mal ausprobiert?
|
AW: Forward in Klassen funktioniert nicht
Zitat:
Was glaubst Du für was die Uses-Klausel da ist. Um Klassen vor einander zu verstecken, oder dafür, dass die Klasse von anderen Klassen erfährt? Zitat:
Denn irgendein Mensch muss irgendeine Eizelle nicht kennen. Aber die Klassen müssen sich gegenseitig kennen, sonst würde die Menschheit aussterben. Zitat:
|
AW: Forward in Klassen funktioniert nicht
Zitat:
Klasse A kennt Klasse B aber nicht umgekehrt. Zum Thema Uses: Wenn ich eine Procedure aus den Sysutils verwenden möchte, dann sollte diese die Procedure aus SysUtils kennen, aber die Procedure aus Sysutils muss nicht unbedingt etwas von meiner procedure wissen. |
AW: Forward in Klassen funktioniert nicht
Zitat:
Wetten hier hat jemand vergessen seine TFruit-Instanz zu erzeugen, zuzuweisen oder Dergleichen? :roll: Immer schön, wenn das Wichtigste fehlt und man erst mühsam danach fragen muß. Und am Ende hatte es rein garnichts mit der ursprünglichen Frage zu tun. |
AW: Forward in Klassen funktioniert nicht
Zitat:
Warum also einen dritten hinzuziehen, wenn die beiden Klassen zusammengehörig sind und gegenseitig miteinander über den direkten Weg agieren können. Bei den Proceduren und Funktionen, welche in einer Klasse angelegt sind macht sich doch auch niemand Gedanken darüber, dass sich ALLE gegenseitig kennen und vorwärts deklariert sind. Also: Ich bin für Vorwärts-Deklarationen auch bei Klassen. |
AW: Forward in Klassen funktioniert nicht
Das ist ja auch nicht generell ein Problem und oft sinnvoll.
Man kann dann aber die beteiligten Klassen nicht mehr (so leicht) verselbständigen und an anderer Stelle einsetzen. Auch wenn sich ein Projekt immer weiter vergrößert kann das irgendwann unübersichtlich werden. Dann würdest Du vielleicht gern eine Klasse in eine eigene Unit legen, da aber alle Klassen mit allen anderen umgehen geht das dann nicht mehr. Forward Deklaration ist sicher kein Problem, aber bei komplexen Projekten ist es besser, von Anfang an auf ordentliche Trennung zu achten. |
AW: Forward in Klassen funktioniert nicht
Zitat:
Das ist wie mit Units, die sich gegenseitig kennen müssen (Stichwort Zirkuläre Referenz). Wenn du so etwas drin hast.... Nee. Versuch es du vermeiden. |
AW: Forward in Klassen funktioniert nicht
[QUOTE=bernau;1283985]
Zitat:
Und weil sie zusammengehören und direkt von einander abhängig sind, stehen sie auch in der selben Unit. Und eine solche Ehe soll der Programmierer dann auch nicht scheiden. |
AW: Forward in Klassen funktioniert nicht
Immer wenn ich auf mein Knie drücke tut es weh, genauso am Arm und am Ohr, sowie am Fuß, eigentlich überall.
Jetzt habe ich meine Diagnose: Finger gebrochen.
Delphi-Quellcode:
// Form object - action taken when
procedure TForm1.FormCreate(Sender: TObject); var apple, banana : TFruit; begin // ACHTUNG, DIESE ZEILEN EINFÜGEN if not Assigned( f ) then raise Exception.Create( 'Finger gebrochen!' ); // DAS WAR ES SCHON - AUSPROBIEREN - WAS SEHEN WIR? f.SetForm(self); // Let us create our fruit objects apple := TFruit.Create(3.5); banana := TFruit.Create(7.0, 1.75); // Show details about our fruits ShowFruit(apple); ShowFruit(banana); end; |
AW: Forward in Klassen funktioniert nicht
Zitat:
Es gibt mittlerweile (also seit ca. 20 Jahren) Grundregeln moderner Softwarearchitektur, die man befolgen kann oder auch nicht. Nur wenn man sie nicht befolgt, dann muss man sich nicht wundern, wenn man dann in einer Diskussion, die sich am Rande auch um diese Regeln dreht, Gegenargumente bekommt. Oder teilweise Kopfschütteln. Zitat:
|
AW: Forward in Klassen funktioniert nicht
:thumb:
|
AW: Forward in Klassen funktioniert nicht
Zitat:
Eine Funktion ist immer dazu da, benutzt zu werden. Kein Mensch würde darauf kommen TPageControl und TTabSheet zu trennen, oder seine komplett selbst programmierte VCL zu benutzen. Sollte man allerdings tun, wenn man auf die "Grundregeln moderner Softwarearchitektur" besteht. |
AW: Forward in Klassen funktioniert nicht
Zitat:
Zitat:
Zitat:
Im Übrigen gilt in der modernen Softwarearchitektur auch und besonders, das man bestehende Frameworks benutzen sollte, wenn dies (TOC) günstiger ist, als selbst etwas zu entwickeln. Also verwende ich zähneknirschend die VCL und auch mal so ein in seiner Freiheit eingeschränktes TTabSheet. |
AW: Forward in Klassen funktioniert nicht
Zitat:
Einerseits sagst Du, dass Forward-Deklarationen von Klassen nicht den "Grundregeln moderner Softwarearchitektur" entsprechen, andererseits verwendest Du Delphi, welches voll ist mit Klassen-Forward-Deklarationen. Entweder sind dann auch Klassen-Forward-Deklarationen "sauberer Code" oder Dein Programm hat KEINEN sauberen Code, denn Dein Programm besteht zu einem sehr großen Teil aus Delhi-Code. Du solltest Dich für eine Variante entscheiden. Zitat:
Zitat:
Auch ein "Goto" war ein sehr gut einzusetzender und effektiver Befehl. |
AW: Forward in Klassen funktioniert nicht
Sir Rufo:thumb:
Ohhhh Danke Dir, das Object wurde noch nicht erstellt Oooohhhhhhhhhh Nur warum ging das mit der Lokalen Variablen dann wäre mir das auch aufgefallen. Ein schönes Weihnachtsfest. Zitat:
|
AW: Forward in Klassen funktioniert nicht
Zitat:
|
AW: Forward in Klassen funktioniert nicht
Der Stack existiert immer, egal ob es das Objekt gibt oder nicht,
drum funktionieren lokale Variablen immer. Globale Variablen liegen auf dem Heap und der ist auch immer da. Felder (Veriablen in der Klasse) liegen immer in der Klassen-Instanz und ist die weg, dann sind die auch weg. :stupid: Die Variable (mit der Klasseninstanz) wird als Self in die Methode reingegeben und solange man nicht auf Self (also auf irgendwas in der Instanz) zugreift, kann auch nichts passieren. Die Methode wird dann quasi zur Klassen-Methode (class function). |
AW: Forward in Klassen funktioniert nicht
Zitat:
|
AW: Forward in Klassen funktioniert nicht
Ich für meinen Teil hab die Schale Popcorn schon hier zu stehen gehabt und gewartet und geschmunzelt.
|
AW: Forward in Klassen funktioniert nicht
Zitat:
Delphi-Quellcode:
procedure ExtendDiscussion(AAnswer: TAnswer; AQuestioner: TQuestioner; AReader: TPostReader)
begin if ((AAnswer.Correct) and (AReader = AQuestioner)) then begin AAnswer.Visible := false; end; end |
AW: Forward in Klassen funktioniert nicht
Zitat:
Vielleicht gibt es ja ein Plugin, welches richtige Antworten schweinchenrosa einfärbt? |
AW: Forward in Klassen funktioniert nicht
Ich wollte hier niemandem die Antwort stehlen, aber im Hinblick auf
![]() empfand ich es hier als angebracht mit dem gesamten Westerwald zu winken als nur mit dem Zaunpfahl. Ein weiteres Darauf-Herumreiten, warum diese oder jene schon frührere gegebene Antwort nicht gesehen wurde sollte sich in Anbetracht der besonderen Situation erübrigen. |
AW: Forward in Klassen funktioniert nicht
:thumb::thumb::thumb:
|
AW: Forward in Klassen funktioniert nicht
Zitat:
Zitat:
Asche auf unser Haupt. |
AW: Forward in Klassen funktioniert nicht
Zitat:
Soetwas ist es immer Wert und hat absolut nichts mit einem Fähnchen im Wind zu tun. Dafür nochmals 3x Daumen hoch für Sir Rufo.:thumb::thumb::thumb: |
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:59 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