AGB  ·  Datenschutz  ·  Impressum  







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

Streams: welche BufSize?

Ein Thema von Cöster · begonnen am 1. Dez 2006 · letzter Beitrag vom 15. Jan 2010
Antwort Antwort
Seite 1 von 2  1 2      
Cöster

Registriert seit: 6. Jun 2006
589 Beiträge
 
Turbo Delphi für Win32
 
#1

Streams: welche BufSize?

  Alt 1. Dez 2006, 17:03
Hi!

Beim Arbeiten mit Streams rufe ich den Konstruktor von TWriter auf. Als Parameter erwartet er u.a. die Größe des Puffers. Welche Zahl muss ich da angeben? Kann man die berechnen? Wenn ja, wie?
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

Re: Streams: welche BufSize?

  Alt 1. Dez 2006, 17:27
Am Besten du ließt dort einfach mit ^^

Dateien schreiben Buffergröße optimieren


[add]
oder mal auf den da unten hören

(Selber nutze ich "fast" nie Streams )
$2B or not $2B
  Mit Zitat antworten Zitat
Der_Unwissende

Registriert seit: 13. Dez 2003
Ort: Berlin
1.756 Beiträge
 
#3

Re: Streams: welche BufSize?

  Alt 1. Dez 2006, 17:29
Hi,
warum genau rufst du denn den Konstruktor von Writer auf? Da sagt doch die Delphi Hilfe extra zu:
Zitat:
Erzeugen Sie Writer-Objekte nicht direkt. Writer-Objekte werden von den Methoden der Stream-Objekte oder in globalen Routinen automatisch erzeugt, die das Streamen initiieren. Dies beinhaltet folgendes:
  • die globale Prozedur ObjectBinaryToText, die ein Writer-Objekt direkt erstellt.
  • die globale Funktion ReadComponentResFile, die ein Datei-Stream-Objekt erstellt, das seinerseits ein Writer-Objekt erstellt.
  • die Methode WriteDescendent von TStream, die ein Writer-Objekt erstellt.

Sobald die Streaming-Operation läuft, sollten Programme die Reader-Objekte nicht direkt bearbeiten. Die Methoden der Reader-, Writer- und Komponentenobjekte rufen sich automatisch gegenseitig auf.
  Mit Zitat antworten Zitat
Cöster

Registriert seit: 6. Jun 2006
589 Beiträge
 
Turbo Delphi für Win32
 
#4

Re: Streams: welche BufSize?

  Alt 1. Dez 2006, 18:41
Zitat von himitsu:
Am Besten du ließt dort einfach mit ^^

Dateien schreiben Buffergröße optimieren
Davon versteh ich ehrlich gesagt fast nur Bahnhof.

Zitat von himitsu:
(Selber nutze ich "fast" nie Streams )
Warum nicht?

Zitat von Der_Unwissende:
warum genau rufst du denn den Konstruktor von Writer auf?
Hm, weil das in einem Beispiel in der Schule auch so war.

Wie schreibt man folgenden einen Code, denn ohne direkt auf den Writer zuzugreifen?

Delphi-Quellcode:
procedure Save(const AFileName: string; Figure: Integer);
var
  F: TFileStream
  W: TWriter;
begin
  F := TFileStream.Create('MyFile.dat', fmCreate);
  W := TWriter.Create(F, 4000);
  W.WriteInteger(Figure);
  W.Free;
  F.Free;
end;
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

Re: Streams: welche BufSize?

  Alt 1. Dez 2006, 18:49
Zitat von Cöster:
Davon versteh ich ehrlich gesagt fast nur Bahnhof.
Du brauchst doch nur auf die Größenangaben zu achten

Zitat von Cöster:
Warum nicht?
Is mir zu umständlich und 's gibt Besseres.


In deinem Beispile hat man 'nen extra Writer verwendet, aber in TFileStream sollte doch wohl schon einer drin sein?

Schau mal in der OH nach TFileStream ... dort müßte es Funktionen mit den Wörtern Read und Write im Namen geben

Delphi-Quellcode:
procedure Save(const AFileName: string; Figure: Integer);
var
  F: TFileStream;
begin
  F := TFileStream.Create('MyFile.dat', fmCreate);
  F.Write...(Figure, SizeOf(Figure));
  // oder F.Write...(Figure, 4);
  F.Free;
end;
bei "..." kann es sein, daß dort noch irgendwas hin muß, z.B. WriteBuffer, oder so, aber da kann dir die OH besser helfen.


PS: bei einem Integer (4 Byte) dürfte eine 4 auch schon reichen, oder du läßt es so, wie es ist
$2B or not $2B
  Mit Zitat antworten Zitat
Der_Unwissende

Registriert seit: 13. Dez 2003
Ort: Berlin
1.756 Beiträge
 
#6

Re: Streams: welche BufSize?

  Alt 1. Dez 2006, 18:54
Zitat von Cöster:
Wie schreibt man folgenden einen Code, denn ohne direkt auf den Writer zuzugreifen?

Delphi-Quellcode:
procedure Save(const AFileName: string; Figure: Integer);
var
  F: TFileStream
  W: TWriter;
begin
  F := TFileStream.Create('MyFile.dat', fmCreate);
  W := TWriter.Create(F, 4000);
  W.WriteInteger(Figure);
  W.Free;
  F.Free;
end;
Na ja, eigentlich schreibst du halt in den Stream:
Delphi-Quellcode:
procedure Save(const AFileName: string; Figure: Integer);
var
  F: TFileStream
  W: TWriter;
begin
  F := TFileStream.Create('MyFile.dat', fmCreate);
  try
    F.Write(Figure, sizeOf(Figure));
  finally
    F.Free;
  end;
end;
Das try...finally Gebilde ist dabei ein Schutzblock. Da du den Stream öffnest solltest du immer dafür sorgen, dass der (eben auch bei Fehlern) geschlossen wird. Alles was unter finally kommt wird immer ausgeführt (egal ob es Fehler gab oder nicht). In einen Stream ganz du jedes Datum ganz untypisiert schreiben, dabei werden wirklich die rohen Bytes geschrieben. sizeOf gibt dir die Größe eines Datums in Byte an. Das klappt zwar gut für primitive Datentypen (Zahlen, Character) und Records, aber nicht mehr für Strings und dyn. Arrays. Bei diesen musst du die Länge mit der Größe eines Elements multiplizieren (length(x) * sizeOf(x[0])), bei Strings kannst du einfach die Länge nehmen. Schreibst du ein dyn. Array in einen Stream, so musst du dort das erste Element (x[0]) übergeben, nicht nur x (x ist das dyn. Array), bei einem String gilt das Selbe, allerdings ist der Index des ersten Elements im String immer 1 statt 0.

Gruß Der Unwissende
  Mit Zitat antworten Zitat
Cöster

Registriert seit: 6. Jun 2006
589 Beiträge
 
Turbo Delphi für Win32
 
#7

Re: Streams: welche BufSize?

  Alt 1. Dez 2006, 20:33
Erstmal danke für das, was ihr beide bisher geschrieben habt.

Zitat von himitsu:
Is mir zu umständlich und 's gibt Besseres.
Zum Beispiel? Ini-Files oder typisierte Dateien halte ich oft für umständlicher. Aber woran hast du denn eigentlich gedacht?

Zitat von Der_Unwissende:
Schreibst du ein dyn. Array in einen Stream, so musst du dort das erste Element (x[0]) übergeben, nicht nur x (x ist das dyn. Array), bei einem String gilt das Selbe
Hm? Für welchen Parameter muss ich das jetzt angeben? Bei der Größe hab ich dich so verstanden, dass man Length(Array)*SizeOf(Array[0]) angibt, bei einem String nur Length(String), was mir auch logisch erscheint, weil 1 Buchstabe ja 1 Byte groß ist. Für den Buffer erschiene es mir aber auch unlogisch, wenn ich nicht den ganzen String übergebe, sondern nur den ersten Buchstaben. Bin ich jetzt blöd?

Wie mach ich das dann beim Lesen, wenn ich nen String hab? Dann weiß ich ja nicht von vornherein, wie viele Bytes er im Stream einnimmt.
  Mit Zitat antworten Zitat
Muetze1
(Gast)

n/a Beiträge
 
#8

Re: Streams: welche BufSize?

  Alt 1. Dez 2006, 23:12
@Der_Unwissende: Wenn man eigene Streams baut bzw. binäre Streams, dann sind die TWriter und TReader Klassen richtig gut nutzbar. Auch weil sie die Datenstruktur dynamisch optimieren und damit bekommt man gute Binärdaten hin. In der Hilfe ist dies vermerkt, damit keiner auf die Idee kommt damit direkt zu hantieren, sie sind aber schon seit sehr vielen Delphi Versionen dafür nutzbar. Schon allein durch die Typüberprüfung und auch automatischen Konvertierungen, ist es ein gutes System. Vor allem ist es bequemer als die Hexereien mit den TStream Nachfahren direkt.
  Mit Zitat antworten Zitat
Benutzerbild von negaH
negaH

Registriert seit: 25. Jun 2003
Ort: Thüringen
2.950 Beiträge
 
#9

Re: Streams: welche BufSize?

  Alt 2. Dez 2006, 11:46
ich stimme Thomas absolut zu, meine Meinung

Also nicht immer gleich vor Allem zurückzucken nur weil irgendeiner sagt tue das nicht ! Alles was in der RTL und VCL verfügbar ist kann man nutzen.

Allerdings erzeugt das Stream Format der TWriter/TReader Klassen auch einen Overhead in der Größe der geschriebenen Daten. Ein direktes binäres Schreiben in den Stream ist also kompakter und die TWriter Klasse hätte nur 4 Vorteile:

1.) typsicheres Auslesen der Daten, man kann keinen String lesen wo ein Integer geswchrieben wurde
2.) der binäre Stream kann über ObjectBinaryToText() in einen Text formatierten Stream umgewandelt werden, so wie bei binären DFMs und textorientierten DFMs
3.) hierarische Datenstrukturen sind möglich, sprich gruppierte und gekapselte Datenstrukturen
4.) man kann alle Nachfahren von TPersistent in diesen Stream speichern und laden, dh. alle published Properties werden autom. erkannt und gespeichert, wie auch die Zeiger-Refrerenzen der Klassen aufgelösst (eventl. Aufruf von RegisterClasses() nötig)

Also schon einige Vorteile, aber das Hauptproblem mit geänderten Datenstruktur-Aufbau bleibt bestehen wie bei binären Streams.

Gruß Hagen
  Mit Zitat antworten Zitat
Muetze1
(Gast)

n/a Beiträge
 
#10

Re: Streams: welche BufSize?

  Alt 2. Dez 2006, 12:49
Zitat von negaH:
ich stimme Thomas absolut zu, meine Meinung
Danke, das geht runter wie Öl...

Zitat von negaH:
Also schon einige Vorteile, aber das Hauptproblem mit geänderten Datenstruktur-Aufbau bleibt bestehen wie bei binären Streams.
Da kann man noch eine Versionsnummer am (relativen) Anfang des Streams einführen und auch dies damit abhandeln - oder BitFelder und Grössenfelder um das sogar noch mit alten kompatibel zu machen. Gibt viele Möglichkeiten dies auch so gut wie es geht auszuschalten...
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 22:50 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