![]() |
records oder klassen?
hey ich habe einge frage und zwra wann sollte man klassen brauchen und wann sollte man records verwenden? kann ich in recrods auch objekte absperichern und falls ja wie mache ich das mit dem konstruktor den ndas geht ja bei einem recrod gar nicht? danke schon mal!:stupid:
|
AW: records oder klassen?
Das wäre einfacher, wenn du einen konkreten Anwendungsfall nennen würdest.
Allgemein würde ich in den meisten Fällen Klassen benutzen. Auch zum Beispiel in Kombination mit Interfaces. Ausnahmen sind zum Beispiel, wenn du Klassenoperatoren verwenden möchtest oder direkt mit reserviertem Speicher arbeiten möchtest, zum Beispiel zur Nutzung der Windows API. |
AW: records oder klassen?
Zitat:
|
AW: records oder klassen?
Beispiel Komplexe Zahl:
Ohne Class Operator:
Delphi-Quellcode:
Mit
TComplex = Record
r: Double; i:Double; End; function ComplexAdd ( a, b: TComplex); TComplex; ... c := ComplexAdd(a, b);
Delphi-Quellcode:
TComplex = Record
r: Double; i:Double; Class Operator Add( a, b: TComplex); TComplex; End; ... c := a + b; |
AW: records oder klassen?
"Historisch" gesehen waren records einmal Klassen, die nur Eigenschaften hatten (keine Methoden etc.). Allerdings sind diese beiden Datentypen immer mehr zusammengrückt, weswegen die Abgrenzung inzwischen etwas schwerer zu verstehen ist. Manchmal wird (auch eher historisch bedingt) das eine oder andere von APIs vorgegeben. Ich denke nicht, dass da man eine allgemeine Regel formulieren sollte, wann man was benutzt. "Falsch" ist keines von beiden.
Hier etwas zu Records: ![]() Und hier was zu Klassen: ![]() Klassenfunktionen sind übrigens Funktionen, die aufgerufen werden können, ohne dass ein Objekt einer Klasse erzeugt werden muss. Damit kann man natürlich innerhalb so einer Klassenfunktion nicht auf Variablen der Klasse zugreifen, weil ja kein Speicher reserviert wurde (d.h. kein Objekt erstellt). |
AW: records oder klassen?
Der Hauptunterschied bleibt aber:
Bei Klassen arbeitet man mit Pointern, bei Records muss man diese explizit benutzen und den Speicher auch ggf. Selbst reservieren und freigeben. |
AW: records oder klassen?
Zitat:
Records: müssen nicht erzeugt und freigegeben werden Klassen: müssen erzeugt und wieder freigegeben werden (Create...Free) |
AW: records oder klassen?
Zitat:
Gerade bei der Nutzung von Klassen kann man das Pointer-Gewusel gut umgehen. Intern sieht das ein wenig anders aus. Und der/die nackte Record hat erst einmal nichts mit Pointern zu tun. Daß Pointer und Records ein leistungsfähiges Gespann sind, würde ich nie in Abrede stellen. Gruß K-H Edith: Zitat:
|
AW: records oder klassen?
Moin recall,
Zitat:
Ursprünglich dienten Records dazu Daten strukturiert speichern und laden zu können. :wink: (da waren Klassen bestenfalls in der Idee vorhanden) Grundsätzlich wäre das dann wohl auch ein Anwendungszweck, bei dem man um Records kaum herumkommt. (auch wenn bei der heutigen Verbreitung von (lokalen) Datenbanken und xml der Bedarf nicht mehr so hoch sein dürfte). Wann auch immer Pointer ins Spiel kommen, man um zugeordnete Funktionen/Prozeduren nicht herumkommt oder diese Datenstrukturen anderweitig zugeordnet werden müssen (z.B. als Object eines Eintrags einer StringListe, würde ich wohl meist auf eine Klasse zurückgreifen. Als Rückgabewert einer Funktion kann es mit einer Klasse schwierig werden, hier wäre dann wohl ein Record sinnvoller. In diesem Falle könnte man dann, ersatzweise, aich einen const Parameter mit einer Klasse übergeben. |
AW: records oder klassen?
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:13 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 by Thomas Breitkreuz