Einzelnen Beitrag anzeigen

Benutzerbild von himitsu
himitsu
Online

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.063 Beiträge
 
Delphi 12 Athens
 
#6

AW: DataSet: Speicherverbrauch berechnen

  Alt 11. Mär 2018, 12:47
Du gehst alle Fields des DataSets durch.

Da jeweils TField.DataSize nehmen und zusammenrechnen.
Das mit der Anzahl der Records multiplizieren (RecordCount + 2 für sowas wie TField.OldValue).
Dann nochmal alle Felder/Records mit TBlobField durchgehn und von jedem Blob einzeln die Größe dazu addieren.

Und am Ende noch bissl Offset für ungenutzte Anteile der reservierten Speicherblöcke auch noch draufrechnen (für jeden einzelnen Record und Blob) ... Speicherfragmentierung


PS: Bei CHAR(x) und VARCHAR(x) mit UTF-8 sind das oftmals 5 Byte pro Char, zuzüglich der Längenangabe für VARCHAR und einem Bit für NULL.
Und TBlob (BLOB, TEXT, usw.) sind das ein Pointer + der Speicher in Form eines TData (per Default, falls die TDataSet-Ableitung nicht was anderes/eigenes implementiert)

Längenangabe und NULL einfach ignorieren (das ist bei DataSize schon drin) und der Rest ist eh schon ausreichend ungenau genug.
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

Geändert von himitsu (11. Mär 2018 um 12:53 Uhr)
  Mit Zitat antworten Zitat