AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

DataSet: Speicherverbrauch berechnen

Ein Thema von haentschman · begonnen am 11. Mär 2018 · letzter Beitrag vom 11. Mär 2018
Antwort Antwort
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.429 Beiträge
 
Delphi 12 Athens
 
#1

DataSet: Speicherverbrauch berechnen

  Alt 11. Mär 2018, 11:42
Hallöle...

mein Vorhaben:

* Stapeldruck einer größeren Menge Aufträge (ca. 3000) mit verschiedenen Belegarten und unterschiedlichem Inhalt
-> verschiedene Formulare für die einzelnen Belegarten (je Belegart 1 Formular)
-> Datenumfang ungefähr wie eine normale Rechnung
-> max. 10 Positionen

meine Idee:

* einen Druck Pool (Klasse mit Liste)
* jeder Druckauftrag bekommt sein eigenes Dataset mit WHERE statt Gesamtdatenmenge mit IN Statement

Frage:

Läßt sich irgendwie der Gesamtspreicherverbrauch (Arbeitsspeicher) berechnen? Formel? Das Meiste machen die DataSets aus...denke ich. Ich hätte gern einen Anhaltspunkt bevor ich loslege... Ansonsten muß ich das Konzept überdenken.

Danke...

Crosspost: https://forum.delphi-treff.de/index....uch-berechnen/

Geändert von haentschman (11. Mär 2018 um 12:38 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von KodeZwerg
KodeZwerg

Registriert seit: 1. Feb 2018
3.691 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: DataSet: Speicherverbrauch berechnen

  Alt 11. Mär 2018, 12:11
Die Unit FastMM hat eine Protokoll Funktion, vielleicht hilft dir das weiter?
Gruß vom KodeZwerg
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.429 Beiträge
 
Delphi 12 Athens
 
#3

AW: DataSet: Speicherverbrauch berechnen

  Alt 11. Mär 2018, 12:18
Danke...aber nicht wirklich.
Es existiert nur ein Konzept. Noch nicht mal das SQL ist erstellt. Ich möchte nur wissen wie speicherlastig das Konzept sein könnte...die Anwendung hat eh schon zuviel.
  Mit Zitat antworten Zitat
Benutzerbild von KodeZwerg
KodeZwerg

Registriert seit: 1. Feb 2018
3.691 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: DataSet: Speicherverbrauch berechnen

  Alt 11. Mär 2018, 12:23
Tut mir leid, da hatte ich was falsch verstanden, mein Tipp galt logischerweise nur bei bereits ausführbaren Anwendungen.

Ps: Vielleicht hast Du ja bereits ein ähnliches Projekt oder eventuell hat Delphi ein Demo-Beispiel ähnlichen Inhalts, da könnte man kurzzeitig FastMM Einbinden, Werte ermitteln und glücklich werden?!
Gruß vom KodeZwerg

Geändert von KodeZwerg (11. Mär 2018 um 12:32 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.429 Beiträge
 
Delphi 12 Athens
 
#5

AW: DataSet: Speicherverbrauch berechnen

  Alt 11. Mär 2018, 12:28

Man könnte ja die einzelnen Größen der benötigten Felder zusammenrechnen... aber ich kenne nicht den Overhead (Speicher) eines Datasets.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.314 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.
Ein Therapeut entspricht 1024 Gigapeut.

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

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.599 Beiträge
 
Delphi 12 Athens
 
#7

AW: DataSet: Speicherverbrauch berechnen

  Alt 11. Mär 2018, 12:55

Man könnte ja die einzelnen Größen der benötigten Felder zusammenrechnen... aber ich kenne nicht den Overhead (Speicher) eines Datasets.
Das hängt ganz von dem verwendeten DataSet ab. Allerdings sind das auch ziemlich tiefe Interna und gegebenenfalls schwer bis überhaupt nicht zu ermitteln.

Als Richtgröße kannst du aber den Vorschlag von Himitsu aufgreifen und Summe über die Spaltengrößen mit der Anzahl der im Speicher gehaltenen Zeilen multiplizieren. Wie viele das sind, hängt halt auch vom verwendeten DataSet und seinen Einstellungen ab. Wenn z.B. eine TFDQuery in den FetchOptions Unidirectional aktiv hat, werden die abgearbeiteten Zeilen immer freigegeben. In Kombination mit einer Einschränkung der RowSetSize kann man den Speicherbedarf schon in Schranken halten.

Bei anderen Datenzugriffskomponenten kann das aber auch anders aussehen.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 12:24 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