Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Algorithmen, Datenstrukturen und Klassendesign (https://www.delphipraxis.net/78-algorithmen-datenstrukturen-und-klassendesign/)
-   -   Spring4D Nullable<T> fHasValue: string; (https://www.delphipraxis.net/203800-spring4d-nullable-t-fhasvalue-string%3B.html)

Dennis07 27. Mär 2020 13:59

AW: Spring4D Nullable<T> fHasValue: string;
 
Zitat:

Zitat von freimatz (Beitrag 1460599)
Es ist aber kein "object" sondern ein record

Naja, das kommt darauf an, wie man object hier interpretiert.
Wenn damit Objekttypen, also
Delphi-Quellcode:
TChild = object(TAncestor)
gemeint sind, dann hast du recht. Allerdings sind ja zunächst einmal
Delphi-Quellcode:
record
bzw.
Delphi-Quellcode:
class
-Instanzen auch Objekte ( -> "Instanzen eines vordefinierten Typs").

Stevie 27. Mär 2020 14:22

AW: Spring4D Nullable<T> fHasValue: string;
 
Zitat:

Zitat von himitsu (Beitrag 1460545)
Weil der String automatisch initialisiert wird und ein Boolean ohne vorherrige Zuweisung sonst einen Zufallswert haben kann.

Korrekt

Zitat:

Zitat von freimatz (Beitrag 1460549)
Bei einem Nullable<Boolean> braucht man dann statt einem Byte dann 9.

Ein Nullable<Boolean> ist auf 32bit 8 Byte groß (wegen dem Alignment). Habe schonmal packed in Betracht gezogen, aber der Speicherverbrauch von Nullables ist mir bisher nicht als triftiges Problem berichtet worden.

Zitat:

Zitat von dummzeuch (Beitrag 1460559)
Man könnte das nach einer Idee von Allen Bauer mit einem Interface auf 4 Bytes reduzieren. Keine Ahnung, warum Stefan das nicht gemacht hat.

Eine string Referenz hat dieselbe Größe wie die eines interfaces (SizeOf(Pointer)) und es ist einfacher, einen Stringwert als "nicht null" Wert zuzuweisen, als mit der handcrafted IMT - zudem kann man das schöner im Debugger anschauen. Hat auch Hallvard Vassbotn in den Kommentaren vorgeschlagen.

Sollt es nachweislich einen Memoryleak durch diese Implementierung geben, dann bitte einen Bugreport mit komplettem Code zum nachstellen erstellen.

freimatz 28. Mär 2020 12:58

AW: Spring4D Nullable<T> fHasValue: string;
 
Zitat:

Zitat von Dennis07 (Beitrag 1460590)
Werden Felder nicht automatisch initialisiert?
Mir war doch so, und die OH sagt sazu:
Object instance data (fields) are also initialized to 0.
...

Zitat:

Zitat von Dennis07 (Beitrag 1460626)
Zitat:

Zitat von freimatz (Beitrag 1460599)
Es ist aber kein "object" sondern ein record

Naja, das kommt darauf an, wie man object hier interpretiert.
Wenn damit Objekttypen, also
Delphi-Quellcode:
TChild = object(TAncestor)
gemeint sind, dann hast du recht. Allerdings sind ja zunächst einmal
Delphi-Quellcode:
record
bzw.
Delphi-Quellcode:
class
-Instanzen auch Objekte ( -> "Instanzen eines vordefinierten Typs").

Nein es kommt nicht drauf an wie "man" es definiert sondern wie es EMB definiert. Und das ist IMHO eindeutig.

@Stevie: bis jetzt habe ich noch nicht die Implementierung in Verdacht.

Dennis07 29. Mär 2020 04:15

AW: Spring4D Nullable<T> fHasValue: string;
 
Ja ne, dürfte ja klar sein, dass ich das so gemeint habe.
In wie fern ist das jetzt bitte "eindeutig", ob es sich um
Delphi-Quellcode:
object
oder einfach Objekte handelt? Geht hier aus dem Kontext keineswegs hervor. Klar kann man sagen "isso", aber das ist ja dann nicht eindeutig.
Was beispielsweise ist dann mit Klassen? Verhalten die sich wie Records oder wie Objects? (Antwort weiß ich zwar, bleibt aber ungeklärt, wenn man den Satz so deutet).
Also ganz klar ein Problem der schwammigen Formulierung des Satzes.

freimatz 30. Mär 2020 13:32

AW: Spring4D Nullable<T> fHasValue: string;
 
Du verwirrst mich. Jetzt versteh ich es selber nicht mehr. Vorher dachte ich wenigstens ich hättes verstanden. :-D
Die Seite mit "Object instance data (fields) are also initialized to 0" habe ich nochmals genauer gelesen. Da geht es doch nur um "initialize a global variable". Darum ging es mir mit den Nullable<T> nicht. Die werden in dem Projekt alle als member von Klassen, also Nachfahren von TObject, verwendet.

himitsu 30. Mär 2020 15:46

AW: Spring4D Nullable<T> fHasValue: string;
 
Globale Variablen, und Felder in Objekten, werden mit 0 initiliaisiert. (bei Globalen kann man auch optional einen anderen Wert vorgeben)
Lokale Variablen in Funktionen werden nicht initialisiert (mit Ausnahme ein paar weniger Typen, wie z.B. der String)

Beim Result von Funktionen mal so und mal so (je nach Typ), aber eigentlich auch nie so, wie man es braucht, also sind praktisch nie sicher "richtig" initialisiert (auch nicht für String und Co.).


Alle Zeitangaben in WEZ +1. Es ist jetzt 13:58 Uhr.
Seite 2 von 2     12   

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz