![]() |
Delphi-Version: 5
Rewrite(f) findet File nicht...
Komisches Verhalten...
In einem Programm werden regelmässig nach schliessen eines Settings - Dialoges Daten weggespeichert. Die Prüfung ob File offen oder existiert schlägt nicht an. Nur die Rewrite - Exception kommt mit einem "EIOnOutError, Datei nicht gefunden.." und ein 0Kb File bleibt. Mal geht's X mal gut, dann wieder nicht.
Delphi-Quellcode:
Suche seit Tagen einen sicher eigenen Fehler und sehe meinen eigenen Blödsinn nicht.
function CDevice.storeSettings(name: string) : integer;
var i:integer; f: file of TSettingsFile; s: TSettingsFile; begin storeSettings := -1; try if IsFileInUse (name) then Begin MessageDlg('File '+name+' is open !!', mtInformation, [mbOk], 0); end; AssignFile(f, name); if not fileexists (name) then Begin MessageDlg(' Gibts nicht !!', mtInformation, [mbOk], 0); end; rewrite(f); except exit; end; //...diverses Speichern Closefile(f) Kann es mit der typisierten Datei zusammen hängen ? |
AW: Rewrite(f) findet File nicht...
Wenn du schon merkst, dass das File in Benutzung ist, dann darft du nicht einfach weitermachen. Du musst erst warten, bis das File nicht mehr in Benutzung ist.
Delphi-Quellcode:
sondern so:
if IsFileInUse (name) then
Begin MessageDlg('File '+name+' is open !!', mtInformation, [mbOk], 0); end; AssignFile(f, name);
Delphi-Quellcode:
und dann später neu versuchen.
if IsFileInUse (name) then
Begin MessageDlg('File '+name+' is open !!', mtInformation, [mbOk], 0); Exit; end; |
AW: Rewrite(f) findet File nicht...
Warum so kompliziert? Kurz, knapp, erläuternd, auswertbar, ...
Delphi-Quellcode:
Und im Ganzen
if not FileExists( name ) then
raise EInOutError.CreateFmt( 'File %s does not exists!', [name] ); if IsFileInUse( name ) then raise EInOutError.CreateFmt( 'File %s is open!', [name] ); AssignFile( f, name ); RewriteFile( f );
Delphi-Quellcode:
function CDevice.storeSettings(name: string): Integer;
var i:integer; f: file of TSettingsFile; s: TSettingsFile; begin if not FileExists( name ) then raise EInOutError.CreateFmt( 'File %s does not exists!', [name] ); if IsFileInUse( name ) then raise EInOutError.CreateFmt( 'File %s is open!', [name] ); AssignFile(f, name); try rewrite(f); //...diverses Speichern Result := ... finally Closefile(f) end; end; |
AW: Rewrite(f) findet File nicht...
Hi,
danke fürs schnelle Feedback. Habs mal so weit umgebaut. Des weiteren Breakpoints beim CloseFile und bei jedem Assignfile was das Projekt hat gesetzt um sicher zu gehen das das File nicht an anderer Stelle geöffnet wird. Das erste mal läuft sauber durch , auch das CloseFile wird angesprungen. Beim nächstem mal geht's in das "File is open.." Was nun tun...nach Filenamen Zwangsschliessen ??
Delphi-Quellcode:
Danke und schönen Sonntach :-)
function CDevice.storerSettings(name: string) : integer;
var i:integer; f: file of TPSettingsFile; s: TSettingsFile; begin storerSettings := -1; if not FileExists( name ) then raise EInOutError.CreateFmt( 'File %s does not exists!', [name] ); if IsFileInUse( name ) then Begin raise EInOutError.CreateFmt( 'File %s is open!', [name] ); exit; end; AssignFile(f, name); rewrite(f); try s.magic := $537916; //...usw. write(f, s); except exit; end; Closefile(f); storeSettings := 0; end; Cali |
AW: Rewrite(f) findet File nicht...
Wenn du eine
Delphi-Quellcode:
wirfst, dann wird der Code danach nicht mehr ausgeführt. Ein
Exception
Delphi-Quellcode:
dahinter ist überflüssig.
Exit
Delphi-Quellcode:
ist so mit das Schlimmste, was man machen kann. Das geht in Richtung Quanten-Computer => ja, nein, eventuell vielleicht (warum auch immer oder nicht)
try
except Exit; end; Warum hast du mein Code-Gerüst so verunstaltet? Damit würdest du wissen ob etwas falsch läuft und die Datei würde immer korrekt geschlossen werden. |
AW: Rewrite(f) findet File nicht...
Hallo,
habs mit deinem "Gerüst" versucht. Hat die Funktion bei FileIsopen per Exception verlassen so wie er es wohl auch sollte. Nur hab ich damit das Problem nicht vom Tisch.. Wie gesagt, beim erstem mal Klappts , incl. Closefile Beim zweitem Mal knallt ab Rewrite(f), File is open wurde also NICHT detektiert und ASsignfile ist durchgelaufen. Beim allen folgenden geht's in deine Exception "File is open" |
AW: Rewrite(f) findet File nicht...
Jupp, das
Delphi-Quellcode:
war mir eine Zeile zu tief gerutscht ;)
try
Hab es im Beitrag korrigiert. |
AW: Rewrite(f) findet File nicht...
@Rufo...Stadthagen ??
Da brauche ich ja nur mal laut ausm Fenster zu rufen...bin aus Rosenhagen, hinter Wiedensahl :-) |
AW: Rewrite(f) findet File nicht...
Zitat:
|
AW: Rewrite(f) findet File nicht...
Welche Chancen hab ich denn das als offen detektierte File zu schliessen
und zu löschen ? Nicht das sich rausstellt das das alte D6 und W7 bei irgendwelchen Fileoperationen nicht das machen was sie sollen... Eim "Umzug" mit diesem Projekt (DLL, incl . Alphatools ) wird bestimmt auch nicht ganz ohne sein. |
AW: Rewrite(f) findet File nicht...
Zitat:
In diesem Beispiel sorgt EXIT dafür, dass Closefile(f); nicht mehr durchlaufen wird, was also ungünstig ist... In D7 wird nach einer Exception der Code innerhalb von Try .. Except nicht mehr durchlaufen, aber der restliche Code innerhalb der Prozedur wird ganz normal durchlaufen... |
AW: Rewrite(f) findet File nicht...
Gebe erstmal auf....
Keinen Plan.... Komisch: Nach dem erstem speichern was ja klappt hab ich versucht die Datei per Explorer zu löschen -> geht, ist also geschlossen. Es wird definitiv kein weiteres Assignfile angesprungen welches diese Datei öffnet. Nach dem nächstem Versuch diese Settings zu speichern kommt bei rewrite die Exception ( nicht bei FileisOpen !! ) und DANACH hab ich eine 0Kb Datei die sich nicht löschen lässt. Hab bei Herrn Amazon nun ne XE8 Pro gekauft. Hoffe der Umstieg wird keine Katastrophe.. |
AW: Rewrite(f) findet File nicht...
Vielleicht macht auch dein Virenscanner Probleme?
Du kannst ja auch mal eine kurze Zeit warten und dann nochmal versuchen. |
AW: Rewrite(f) findet File nicht...
Ich würde grundsätzlich immer try..finally innerhalb von try..except benutzen...
Der Schutzblock steht ja auch bei SirRufo schon mit drin...
Delphi-Quellcode:
Ist halt immer die Frage wie detailiert braucht man ein ExceptionHandling... schließlich kann man das noch um einiges erweitern...
Function CDevice.storerSettings(name: string) : integer;
Var i: integer; f: file of TPSettingsFile; s: TSettingsFile; Begin Try storeSettings := -1; If Not FileExists( name ) Then raise EInOutError.CreateFmt( 'File %s does not exists!', [name] ); If IsFileInUse( name ) Then raise EInOutError.CreateFmt( 'File %s is open!', [name] ); AssignFile(f, name); Try Rewrite(f); s.magic := $537916; //...usw. Write(f, s); Finally Try Closefile(f); // oder direkt in separater, abgesicherter Prozedur... storeSettings := 0; Except Info + StandardExceptionHandling.... was auch immer... storeSettings := -1; End; End; Except // Standard ExceptionHandling, was auch immer man möchte... End; End; |
AW: Rewrite(f) findet File nicht...
Versuch mal die Methode zu beschreiben (dokumentieren). Wenn du einen Roman dazu schreiben musst, dann machst du dort zu viel.
Und ein
Delphi-Quellcode:
was die gesamte Methode umschliesst, die eine echte Arbeit erledigt, ist vom Konzept her falsch.
try except
Die Methode vorher, die diese aufruft, legt den Namen fest. Dort hätte ich eine Möglichkeit vernünftig auf diese Exceptions zu reagieren (z.B. einen anderen Dateinamen). Also kommt das Exception-Handling dort hinein, oder man lässt die einfach hochpoppen. |
AW: Rewrite(f) findet File nicht...
Ich vermute, dass das wahre Problem nicht in dieser Funktion liegt, sondern schon vorher irgendwas Dummes passiert, z.B. Speicher überschrieben. Beim "Wiederholen" tritt es dann auf. Darum würde ich erst mal mit
Code:
compilieren und dann müsste man doch was sehen?
{$Q+,R+, D+, L+}
|
AW: Rewrite(f) findet File nicht...
Zitat:
Zitat:
Zitat:
|
AW: Rewrite(f) findet File nicht...
Über die Art und Weise wie man Exceptions behandelt, wirst du sicher mehrere Meinungen bekommen, und jeder ist überzeugt, er macht es richtig. Meine Meinung ist: Wenn es nichts "zu behandeln" gibt, dann musst du dem User die Exception zeigen, weil du ja selber nicht darauf reagieren kannst. Aber, wegen dem "Zeigen" schmiert noch lange kein Programm ab.
Bei Exceptions stellt sich doch immer zuerst die Frage, wer hat sie verursacht? In diesem Fall ist die Frage relativ einfach zu beantworten: Du! Denn, wenn ein Dateizugriff das erste mal funktioniert, und das zweite mal nicht, dann hast du irgendwo einen Bug produziert, und der sollte/muss weg. Wenn du dich nicht darum kümmerst, kann das unangenehme Folgen haben. Ich hatte noch keinen Kontakt mit FreePascal oder Lazarus, aber da gibt es doch sicher auch einen Debugger. Was kommt denn dabei raus, wenn du wie von mir vorgeschlagen mit {$Q+,R+, D+, L+} compilierst? |
AW: Rewrite(f) findet File nicht...
Hmmm, ich weiß nicht was da "abschmiert". Im Gegenteil, dein Programm bleibt eher stabil.
Oder wie willst du hier irgendwas in den Stream schreiben, wenn du
Delphi-Quellcode:
Aber die Methode vorher, die könnte etwas machen. Wenn es ein Problem mit dem FileStream gab (
procedure DoSaveFoo( AFoo: TFoo; AFileName : string );
var LFooData: TBytes; LStream: TStream; begin // Guard Block - zu 99.9% ein Programmiererfehler, wenn das kommt // Kein Foo, dann kann ich nichts machen => tschüssi if not Assigned( AFoo ) then raise EArgumentNilException.Create('AFoo'); // Kein Dateiname, dann kann ich nichts machen => tschüssi if AFileName.IsEmpty then raise EArgumentNilException.Create('AFileName'); LFooData := SerializeFoo( AFoo ); LStream := TFileStream.Create( AFileName, fmCreate or fmShareExclusive ); try LStream.WriteData( LFooData, Length( LFooData ) ); finally LStream.Free; end; end;
Delphi-Quellcode:
= alle Exceptions von
EFileStreamException
Delphi-Quellcode:
ohne die normalen Exceptions die
TFileStream
Delphi-Quellcode:
wirft), dann wird das 9 mal mit einem neuen Dateinamen versucht. Wenn das nicht funktioniert hat, dann wird diese Exception auch weitergereicht (angezeigt).
TStream
Alle anderen Exceptions laufen einfach durch und werden direkt angezeigt.
Delphi-Quellcode:
procedure SaveFoo();
var LFoo: TFoo; LFooFileName: string; LRetry: Integer; begin LFoo := TFoo.Create; try LRetry := 0; while true do begin LFooFileName := GetTempFileName(); try DoSaveFoo( LFoo, LFooFileName ); Break; except on E: EFileStreamError do begin Inc( LRetry ); if LRetry = 10 then raise; end; end; end; finally LFoo.Free; end; end; |
AW: Rewrite(f) findet File nicht...
Die function CDevice.storeSettings(name: string) : integer; liefert statt boolean/nachvollziehber INTEGER.
Das "Hab bei Herrn Amazon nun ne XE8 Pro gekauft. Hoffe der Umstieg wird keine Katastrophe.. " wird alle Probleme lösen! Geld statt Hirn löst alle Probleme, denn dann kann man statt Denken das Denkenlassen bezahlen ;-) MfG |
AW: Rewrite(f) findet File nicht...
@mm1256:
Danke für die Compiler Info, kann ich vielleicht mal brauchen... @SirRufo: Besten Dank für das Beispiel... Sorry Leute, ich hab' das Thema gar nicht gestartet, bin aufgrund des ExceptionHandlings auf den Zug aufgesprungen, weil mich das interessierte... Kann schlecht testen ob das funzt, da gar nicht mein Programm bzw. Problem... Ich bin dann mal weg... nichts für ungut... |
AW: Rewrite(f) findet File nicht...
Schande über mich....
{+I} , einen Compilerschalter, aus versehen gelöscht... Wenns nicht mehr geht das Projekt in die Ecke werfen und ein paar Tage später wieder ran. Mann sieht seinen eigenen Blödsinn nicht.. Noch mal danke für die Hilfe, aber gegen eigene Blindheit hilft nix... Gruss Calli . . der schon das nächste Problem hat.. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:07 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-2025 by Thomas Breitkreuz