AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Hohe Ressourcennutzung bei Verwendung von ZLIB (ZLIBEX)
Thema durchsuchen
Ansicht
Themen-Optionen

Hohe Ressourcennutzung bei Verwendung von ZLIB (ZLIBEX)

Ein Thema von maanton · begonnen am 25. Feb 2008 · letzter Beitrag vom 26. Feb 2008
Antwort Antwort
maanton

Registriert seit: 10. Sep 2007
16 Beiträge
 
#1

Hohe Ressourcennutzung bei Verwendung von ZLIB (ZLIBEX)

  Alt 25. Feb 2008, 17:04
Hallo !

Ich kämpfe gerade mit der ZlibEX in Delphi 6 herum . Hab auch schon im Netz gesucht... .

Problem : Mein Programm soll verschiedene, auch grosse Zip-Dateien (mit grossen Dateien drin) dekomprimieren können (> 1GB, spaeter eigenes "Format" > 2GB), der ausführende Rechner hat jedoch mit Sicherheit nicht soviel Speicher.

Performance ist hier nicht unbedingt ein Thema.
Essentiell ist, dass während des Entpackens dieses durch <ESC> abgebrochen werden kann (also Tastendruck, Aufruf MessageHandler,...) und Bildschirmaktualisierung (Laufbalken, Restzeit,...) durchgeführt wird.

Die Beispiele, welche ich gefunden habe arbeiten so (ich schenk mir jetzt den "Balast" drumherum):

...
var MemStream : TMemoryStream;
DateiStream : TStream;
Dekompr : TZDecopressionStream;
UnkompGroesse : integer;
sBuffer : string;
...
begin
// DateiStream.Create;
MemStream := TMemoryStream.Create;
if (ZipEintrag.GetComprDaten(MemStream) > 0 then begin {wenn Daten da und Init der internen Daten}
UnkompGroesse := ZipEintrag.SizeUncompressed;
Decompr := TZDecomressionStream.Create(MemStream); <- Hier Speicherbelastung
nGelesen := Decompr.Read(sBuffer[1],UnkompGroesse); {Lesen, Entpacken und in SBuffer schreiben}
DateiStream.Write(sBuffer[1],UnkompGroesse);
Decompr.Free;
end;
MemStream.Free;
// DateiStream.Free;
end;

Funktioniert fantastisch. Und alles in einem Rutsch. Leider wird hierbei das Memory des Rechners mit Speichergebrauch der Grösse der Daten belastet.

Wie geht sowas blockweise? Gibts dafür ein CodeSample und wenn ja wo?

Z.B.
...
//Grundeinstellungen : Positionieren auf Zip-Datei als TFilestream, Einlesen der Grunddaten
While not EndeZipeintrag()
// Lese 64k Block
// Dekomprimier ihn
// Abbruch prüfen, Bildschirm aktualisieren
// schreib raus
end;
// Aufräumen

Gruss
  Mit Zitat antworten Zitat
Benutzerbild von stoxx
stoxx

Registriert seit: 13. Aug 2003
1.111 Beiträge
 
#2

Re: Hohe Ressourcennutzung bei Verwendung von ZLIB (ZLIBEX)

  Alt 25. Feb 2008, 17:13
Zitat:
Essentiell ist, dass während des Entpackens dieses durch <ESC> abgebrochen werden kann (also Tastendruck, Aufruf MessageHandler,...) und Bildschirmaktualisierung (Laufbalken, Restzeit,...) durchgeführt wird.
in einen eigenen seperaten Thread packen ...


und wenn alles gewünschte nicht klappt, ... bei ganz großer Lust kannst Du Dich ja mal selber an Zip versuchen

http://www.koders.com/delphi/fid6D05...789.aspx?s=zip
Phantasie ist etwas, was sich manche Leute gar nicht vorstellen können.
  Mit Zitat antworten Zitat
Muetze1
(Gast)

n/a Beiträge
 
#3

Re: Hohe Ressourcennutzung bei Verwendung von ZLIB (ZLIBEX)

  Alt 25. Feb 2008, 18:00
ZIP als Format und dessen Komprimierung ist nicht gleich der zLib!!!
  Mit Zitat antworten Zitat
maanton

Registriert seit: 10. Sep 2007
16 Beiträge
 
#4

Re: Hohe Ressourcennutzung bei Verwendung von ZLIB (ZLIBEX)

  Alt 25. Feb 2008, 22:04
Zitat:
ZIP als Format und dessen Komprimierung ist nicht gleich der zLib!!!
Korrekt; ungenau von mir ausgedrückt; jedoch egal, da ich auch die ZlibEx zum Packen verwende. Bei einer späteren Version werde ich die LocalFileHeader, ... ändern um >2 GB zu können. Damit bin ich dann inkompatibel zu Winzip, Winrar - ist auch egal, solange ich das nur richtig mache... .

Zitat:
in einen eigenen seperaten Thread packen ...
Funktion läuft schon in eigenem Thread. Wenn ich jedoch an meinen Thread eine message schicke, kommmt diese erst nach Abschluss der (Pack-/Entpack-)Prozedur an. Ich muss also während des Entpackens immer wieder mal die messages abarbeiten, damit ich diese Abbrech-Info in meinen Thread reinbekomme. Man kann das sicher auch anders machen, aber ich will es eigentlich "sauber" halten... .

Zitat:
...bei ganz großer Lust kannst Du Dich ja mal selber an Zip versuchen
Hab ich schon mal. Hat mich -damals unter DOS- "richtig" glücklich gemacht. (Im Endstadium mit Inline-Assembler und so). Wollt ich mir nicht unbedingt nochmal geben. Nerven und Zeitgründe. Daher auch Benutzung einer lib und Inspiration durch Anwendungs-Codesamples.
Die Bibliothek wird jedoch -anscheinend- immer mit Streams verwendet, obwohl - so scheint es mir - auch Funktionalitäten für "blockweises" Entpacken vorhanden sind.


Ich suche also ein Anwendungsbeispiel, welches die Lib mit "blockweisem" Entpacken verwendet.
  Mit Zitat antworten Zitat
Benutzerbild von Union
Union
Online

Registriert seit: 18. Mär 2004
Ort: Luxembourg
3.492 Beiträge
 
Delphi 7 Enterprise
 
#5

Re: Hohe Ressourcennutzung bei Verwendung von ZLIB (ZLIBEX)

  Alt 26. Feb 2008, 08:53
Ohne die ZLib intern genau zu kennen würde ich vorschlagen mit Chunking zu arbeiten. D.h. Du legst ein eigenes Envelope-Format fest und verwaltest Deine "Blöcke" selber:
Code:
Signatur
  Startadresse des übernächsten Blocks (0=letzter)
  ZLib-Komprimierte Daten
Das Schreiben wäre dann wie folgt:
Code:
Signatur schreiben
Solange Datei nicht zu Ende
   Teilstream aus Datei erzeugen und komprimieren
   Startadresse nächster Block aus Position und Länge schreiben
   Teilstream anhängen
Und das Lesen:
Code:
Signatur prüfen
Entkomprimierte Datei leer erzeugen
Solange Datei nicht zu Ende
   Startadresse nächster Block lesen
   Länge des komprimierten Blocks errechnen
   Komprimierten Block lesen
   Entkomprimieren und an entpackte Datei anhängen
Ibi fas ubi proxima merces
sudo /Developer/Library/uninstall-devtools --mode=all
  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 18:22 Uhr.
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