also könnte es so aussehn, als wenn der Virenscanner die Datei noch geöffnet hat.
abgesehn, daß zur Sicherheit in DoSave in paar Try-Except/Finally nicht schaden könnten, damit bei einem/dem Fehler nicht vergessen wird etwas freizugeben ... vorallem die Datei zu schließen.
PS: wenn der Code mehrmals die Minute aufgerufen wird, warum öffnest du diese Datei dann ständig neu?
könnte sie denn nicht einmal geöffnet und die ganze Zeit über offen gelassen werden?
Da IsFileInUse scheinbar nichts bringt, da zwischen diesem und TFileStream.Create die Datei immernoch gesperrt werden kann (bzw. was anscheind auch schon passiert ist):
Delphi-Quellcode:
procedure DoSave();
var Stream: TFileStream;
XMLFile:
String;
DomToXmlParser1: TDomToXmlParser;
DomImplementation1: TDomImplementation;
FDoc: TDOMDocument;
FNodeElement: TDomElement;
B: Boolean;
begin
XMLFile:='
test.xml';
// ----- XML-Zeugs -----
DomImplementation1:=TDomImplementation.Create(
nil);
FDoc := TDomDocument.Create(DomImplementation1);
DomToXmlParser1:=TDomToXmlParser.Create(
nil);
DomToXmlParser1.DOMImpl:=DomImplementation1;
// --- XML root für Schnittstelle anlegen ---
FNodeElement:=TDomElement.Create(FDoc, '
TEST');
FDoc.AppendChild(FNodeElement);
B := False;
repeat
try
Stream := TFileStream.Create(XMLFile, fmCreate);
B := True;
except
Sleep(0);
end;
until B;
try
DomToXmlParser1.WriteToStream(FDoc, '
UTF-8', Stream);
finally
Stream.Free;
end;
FNodeElement.Free;
DomToXmlParser1.Free;
FDoc.Free;
DomImplementation1.Free;
end;
OK, es ist nicht wirklich optimal und vorallem ein Except ohne Fehlerbehandlung wird nicht grad gern gesehn, aber was soll's
(zusetzlich noch ein (paar) Try-Finally für das ganze
XML-Zeugs könnten dennoch nicht Schaden)