Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Sonstige Fragen zu Delphi (https://www.delphipraxis.net/19-sonstige-fragen-zu-delphi/)
-   -   Delphi Was bringt ein "packed" bei "record packed"? (https://www.delphipraxis.net/126773-bringt-ein-packed-bei-record-packed.html)

Helmi 2. Jan 2009 09:45


Was bringt ein "packed" bei "record packed&qu
 
Hallo,

was ich immer schon mal fragen wollte, was bringt ein "packed" bei "record packed"?

Aus der Hilfe werd ich nicht so ganz schlau:
Zitat:

Zitat von Delphi-Hilfe
Per Voreinstellung sind die Werte in einem strukturierten Typ in einem Word- oder Double-Word-Raster ausgerichtet, um den Zugriff zu beschleunigen. Wenn Sie einen strukturierten Typ deklarieren, können Sie das reservierte Wort packed einfügen, um die Daten in komprimierter Form zu speichern:

type TNumbers = packed array[1..100] of Real;

Die Verwendung von packed verlangsamt den Zugriff auf die Daten. Im Falle eines Zeichen-Arrays beeinflusst packed auch die Kompatibilität der Typen.

Das heisst es: "um die Daten in komprimierter Form zu speichern", aber wie wird das gemacht?
Was für einen Vorteil hat das packed?

Luckie 2. Jan 2009 09:55

Re: Was bringt ein "packed" bei "record packe
 
Normalerweise sind die Daten in einem Record an 4-Byte Grenzen ausgerichtet. Beispiel:
Delphi-Quellcode:
TDemo = record
  b: Byte;
  c: Byte;
end;
Ausrichtung im Speicher:
Code:
0  1  2  3  |  4  5  6  7
b b       |  c c
Deklarierst du den Record als packed sieht der Record im Speicher wie folgt aus:
Code:
0  1  2  3
b b c c
Die Ausrichtung an 4-Byte Grenzen macht die Verarbeitung einfacher, weil eine 32-.Bitz CPU sowieso immer 4-Byte auf einmal aus dem Speicher holt, egal, um was für einen datentyp es sich handelt. Sind die daten jetzt an 4-Byte Grenzen ausgerichtet, muss die CPU die Daten nicht noch "nachbearbeiten". Man hat also einen Performance Vorteil. Allerdings aus Sicht des Programmierers ist es praktischer einen Record als packed zu deklarieren, da man keine Probleme bekommt, wenn sich in Zukunft die Ausrichtung ändert; auf 64-Bit CPUs zum Beispiel.

Dann muss man noch manchmal berücksichtigen, wie API-Funktionen Strukturen übergeben haben wollen.

Helmi 2. Jan 2009 09:59

Re: Was bringt ein "packed" bei "record packe
 
Danke für die anschauliche Erklärung!

Dann kann ich daraus schliessen, dass ein "packed" den Speicherverbrauch der Application vermindert?

Luckie 2. Jan 2009 10:02

Re: Was bringt ein "packed" bei "record packe
 
Siehe noch mein Edit.

Zu deiner Frage, ja. Aber fallen die Größenordnungen ins Gewicht? Wichtiger ist es eher nicht mehr benötigte Objekte udn Speicher wieder frei zu geben.

Mit einem Compilerschlater kann man übrigens das Alignment anpassen. Das nur noch der Vollständigkeit halber.

Helmi 2. Jan 2009 10:04

Re: Was bringt ein "packed" bei "record packe
 
Also gehts mehr nur um die Aufwärtskompatibiltät (klingt komisch) der Software auf zukünftigere Systeme...

Oreaden 2. Jan 2009 10:05

Re: Was bringt ein "packed" bei "record packe
 
Zitat:

Zitat von Luckie
aus Sicht des Programmierers ist es praktischer einen Record als packed zu deklarieren, da man keine Probleme bekommt, wenn sich in Zukunft die Ausrichtung ändert; auf 64-Bit CPUs zum Beispiel.

Einen schönen Guten Morgen Luckie,

wie kann man sich das Vorstellen, dass hierbei Probleme auftreten werden? Aktuell sind wir, das Orakel und ich, am rätseln und die Kristallkugel bringt nur wirres Zeug. Außerdem, was hat dies mit einer 64Bit CPU zu tun :glaskugel:

Ratlose Grüße
OREADEN

Luckie 2. Jan 2009 10:14

Re: Was bringt ein "packed" bei "record packe
 
Nehmen wir an es gibt einen 64-Bit Compiler. Dort wird das Alignment bei 64-Bit liegen und nicht bei 32-Bit. Jetzt hast du folgenden Record deklariert:
Delphi-Quellcode:
TKontakt = record
  Name: String[25];
  Vorname: String[15];
  Telefonnumer: String[12];
end;
Diesen schreibst du in eine Datei und liest ihn auch wieder aus. Kompilierst du dein Programm mit einer 32-bittigen Ausrichtung klappt alles wunderbar. Jetzt hast du einen 64-Bit Compiler und compilierst das Programm neu. Schon hast du nur noch Datenmüll beim Lesen, weil die Daten mit einer 32-Bit Ausrichtung geschrieben wurden. Das kann man natürlich beheben, in dem man per Compilerschalter wieder eine 32-Bit Ausrichtung erzwingt. Aber denkt man auch daran? Oder sucht man den Fehler an allen möglichen anderen Stellen? Und solche Probleme erspart man sich, wenn man den Record als packed deklariert, dann kann man das Programm mit jeden beliebigen Alignment kompilieren und es funktioniert. Ist sinnvoll, wenn man Prgrammcode weitergibt oder mit anderen Programmierer zusammenarbeitet. Erspart eben viel Ärger. Und wenn man in eine Datei schreibt, wird der Overhead auch kleiner.

jbg 2. Jan 2009 10:18

Re: Was bringt ein "packed" bei "record packe
 
Zitat:

Zitat von Luckie
Kompilierst du dein Programm mit einer 32-bittigen Ausrichtung klappt alles wunderbar.

Bis auf, dass man auch Daten, die gar nicht zum Record gehören schreibt, da sie zwischen den einzelnen ausgerichteten Record-Feldern liegen.

Übrigens, das Vorgabe-Alignment liegt (auch schon bei Delphi 7 ) bei 8 Byte und nicht wie hier mehrmals erwähnt bei 4 Byte.

Luckie 2. Jan 2009 10:35

Re: Was bringt ein "packed" bei "record packe
 
Zitat:

Zitat von jbg
Übrigens, das Vorgabe-Alignment liegt (auch schon bei Delphi 7 ) bei 8 Byte und nicht wie hier mehrmals erwähnt bei 4 Byte.

Gut, spielt aber für das Verständnis keine Rolle.

Helmi 2. Jan 2009 10:52

Re: Was bringt ein "packed" bei "record packe
 
Danke für die Erklärungen :-)


Alle Zeitangaben in WEZ +1. Es ist jetzt 03:09 Uhr.
Seite 1 von 2  1 2      

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