Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Ist es möglich eine Datei zu lesen ohne das Löschen der Datei zu blockieren? (https://www.delphipraxis.net/189850-ist-es-moeglich-eine-datei-zu-lesen-ohne-das-loeschen-der-datei-zu-blockieren.html)

Mikkey 30. Jul 2016 12:08

AW: Ist es möglich eine Datei zu lesen ohne das Löschen der Datei zu blockieren?
 
Relativ simple Umgehung des Problems:

Klappt das Löschen nicht, wird die Datei nach einem bestimmten Muster umbenannt. Dein Watcher beseitigt regelmäßig die so entstandenen Dateileichen.

Edit:
Das (nicht löschen sondern umbenennen) könnte auch zum Standardverhalten werden, dann werden die Worker-Prozesse nicht unnötig mit "Dateisystem-Geraffel" aufgehalten.

BUG 30. Jul 2016 18:29

AW: Ist es möglich eine Datei zu lesen ohne das Löschen der Datei zu blockieren?
 
Zitat:

Zitat von Mikkey (Beitrag 1343789)
Klappt das Löschen nicht, wird die Datei nach einem bestimmten Muster umbenannt. Dein Watcher beseitigt regelmäßig die so entstandenen Dateileichen.

Er löscht ja nicht selbst, sondern unbeeinflussbare Drittprogramme.

nahpets 30. Jul 2016 20:07

AW: Ist es möglich eine Datei zu lesen ohne das Löschen der Datei zu blockieren?
 
Andere Möglichkeit:

Kopie der Datei erstellen, die man lesen will und die Kopie löschen, wenn man sie nicht mehr benötigt.

himitsu 31. Jul 2016 10:53

AW: Ist es möglich eine Datei zu lesen ohne das Löschen der Datei zu blockieren?
 
Zitat:

Zitat von nahpets (Beitrag 1343811)
und die Kopie löschen, wenn man sie nicht mehr benötigt.

Oder gleich die Kopie so erstellen, dass sie sich selber löscht.
CreateFile + FILE_ATTRIBUTE_TEMPORARY

Oder garkeine physische Datei erstellen (in den Arbeitsspeicher einlesen).

Im Grunde aber egal, denn die Originaldatei müsste man dennoch öffnen und so lange warten, bis der Inhalt ausgelesen/kopiert wurde.

tcoman 1. Aug 2016 16:58

AW: Ist es möglich eine Datei zu lesen ohne das Löschen der Datei zu blockieren?
 
Da ich kein Experte bin sondern nur anwendenter Laie,
lese / lade ich Dateien immer mit BlockRead();

Wenn ich den FileMode richtig setze, kann ich die geladene
Datei in einem Drittprogramm loeschen.

Delphi-Quellcode:
function _readfile: boolean;
var F : File Of Byte;
    ior : integer;
begin
ior:=0;
AssignFile(F, 'X:\Dir\Filename.ext');
FileMode:=fmOpenRead; //alternate: fmOpenReadWrite
{$I-} Reset(F);
{$I+} inc(ior, IORESULT);
...
{$I-} BlockRead();
{$I+} inc(ior, IORESULT);
...
{$I-} CloseFile(F);
{$I+} inc(ior, IORESULT);
...
result:=(ior = 0);
end;
Alles ohne Gewehr.
MfG,
Terence

p80286 1. Aug 2016 17:23

AW: Ist es möglich eine Datei zu lesen ohne das Löschen der Datei zu blockieren?
 
Zitat:

Zitat von HeZa (Beitrag 1343751)
Mein Wunsch:
Wenn während meines Leseversuchs versucht wird die Datei zu löschen, soll mein Leseversuch scheitern, das Löschen aber erfolgreich sein. Ist so etwas (entgegen meinen Erwartungen) realisierbar?

und der Vorschlag aus #8
FILE_SHARE_DELETE

Wobei, wenn das Delete in Deinen Lesevorgang läuft, Du nur Schrott gelesen hast.

Gruß
K-H

HeZa 2. Aug 2016 10:15

AW: Ist es möglich eine Datei zu lesen ohne das Löschen der Datei zu blockieren?
 
Hallo,

erst einmal Danke für die Tipps und Infos.

Wie ich bereits im Anfangsposting erklärte, habe ich keinen Einfluss auf die Programme die diese Sperrdateien erzeugen und löschen. Diese Programme und insbesondere der Umgang mit den Sperrdateien ließen sich bestimmt verbessern, leisten aber trotzdem wertvolle Arbeit für uns. Die Änderung dieser Programme liegt aber außerhalb meiner Möglichkeiten.

Tatsache bleibt, dass ein Leseversuch das Löschen einer Sperrdatei durch diese Programm scheitern lässt und diese Programme darauf nicht sinnvoll reagieren und somit die Sperrdatei erhalten und die Resourcen gesperrt bleiben.

Die einzige machbare Möglichkeit ist mit (hier erwähnten) ShadowCopy zu arbeiten. Das ist für meine Verwendung, aber wie mit Kanonen auf Spatzen schließen. Also werde ich auf das Lesen der Daten verzichten (das wäre eine sinnvolle/interessante Ergänzung gewesen, aber nicht zwingend notwendig) und wende mich anderen Aufgabenstellungen zu.

Ciao HeZa

Daniel 2. Aug 2016 10:39

AW: Ist es möglich eine Datei zu lesen ohne das Löschen der Datei zu blockieren?
 
Danke für die abschließende Rückmeldung. :-)

himitsu 2. Aug 2016 13:34

AW: Ist es möglich eine Datei zu lesen ohne das Löschen der Datei zu blockieren?
 
Man hätte es vielleicht auch noch mit einer Transaction versuchen können, aber ich hab keine Ahnung, ob und wie sich das auf Schreib-/Löschversuche durch andere Programme auswirkt.
Allerdings würde ich "vermuten", dass sich für die Anderen nichts ändert, gegenüber einem "normalen" CreateFile und dessen Sperren/Freigaben.

MSDN-Library durchsuchenCreateFile MSDN-Library durchsuchenCreateFileTransacted


Meine Interpretation
Transaction = schütze Andere und die Datei vor mir
ShadowCopy = schütze mich vor den Anderen


Und die ganz harte Variante (Thread-Priorität = Critical) wäre vielleicht möglich, aber auch keine gute Lösung.
> der eigene Prozess nimmt die CPU voll in Besitz, während sie auf die Datei zugreift ... andere Programme kommen währenddessen zu nichts und kommen erst nach dem Zugriff wieder zu sonstwas, wie z.B. um die Datei dann zu löschen.


Alle Zeitangaben in WEZ +1. Es ist jetzt 02:28 Uhr.
Seite 2 von 2     12   

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