Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   E/A Fehler 103 beim Assignfile (https://www.delphipraxis.net/213332-e-fehler-103-beim-assignfile.html)

TM6 11. Jul 2023 13:27

Delphi-Version: 5

E/A Fehler 103 beim Assignfile
 
Ich habe hier ein Problem, welches ich nicht verstehe.
Ich versuche zu testen, ob ich eine Datei schreiben kann.

Code:
var
  lFile            : file     ;
begin
  if not FileExists( pDateiName ) then
    exit;

  FileMode := fmOpenReadWrite;

  assignfile( lFile , pDateiName );

...
end;
Dabei erhalte ich schon beim AssignFile den I/O Error 103.

Wenn ich das per try ... except abfange und assignfile noch einmal aufrufe, dann funktioniert es.

Das Problem taucht nur auf, wenn ich vorher in einer anderen unit (vollkommen andere Datei) einen nicht erfolgreichen Aufruf (Res <> 0 ) in der folgenden Art hatte (Datei pPath war schreibgeschützt)

Code:
  AssignFile(  lTestFile , pPath );
  if IOResult = 0 then begin
    rewrite( lTestFile , 1 );
    Res := IOResult;
    CloseFile( lTestFile );
  end;
Wo ist hier der Fehler?

peterbelow 11. Jul 2023 13:42

AW: E/A Fehler 103 beim Assignfile
 
Zitat:

Zitat von TM6 (Beitrag 1524438)
Ich habe hier ein Problem, welches ich nicht verstehe.
Ich versuche zu testen, ob ich eine Datei schreiben kann.

Code:
var
  lFile            : file     ;
begin
  if not FileExists( pDateiName ) then
    exit;

  FileMode := fmOpenReadWrite;

  assignfile( lFile , pDateiName );

...
end;
Dabei erhalte ich schon beim AssignFile den I/O Error 103.

Wenn ich das per try ... except abfange und assignfile noch einmal aufrufe, dann funktioniert es.

Das Problem taucht nur auf, wenn ich vorher in einer anderen unit (vollkommen andere Datei) einen nicht erfolgreichen Aufruf (Res <> 0 ) in der folgenden Art hatte (Datei pPath war schreibgeschützt)

Code:
  AssignFile(  lTestFile , pPath );
  if IOResult = 0 then begin
    rewrite( lTestFile , 1 );
    Res := IOResult;
    CloseFile( lTestFile );
  end;
Wo ist hier der Fehler?

Setz IOResult auf 0 bevor Du irgendwelche Dateioperationen machst, das ist sicherer. Noch besser: vergiss diese uralten Dateifunktionen und verwende TFilestream et al., da ist die Fehlerbehandlung wesentlich konsistenter.

Uwe Raabe 11. Jul 2023 13:43

AW: E/A Fehler 103 beim Assignfile
 
Lass mal das CloseFile weg, wenn der IOResult einen Fehler meldet.

TM6 11. Jul 2023 14:07

AW: E/A Fehler 103 beim Assignfile
 
Zitat:

Zitat von Uwe Raabe (Beitrag 1524442)
Lass mal das CloseFile weg, wenn der IOResult einen Fehler meldet.

Das scheint zu funktionieren.
Ich wäre nicht auf die Idee gekommen, dass es daran liegen könnte.

In der Hilfe steht ja nur etwas von müssen und nicht dürfen:
Zitat:

Wenn ein E/A-Fehler auftritt, schließt Rewrite die Datei. Sie müssen CloseFile nicht aufrufen.

Danke!

Sollte man dann CloseFile allgemein nur situationsbedingt nutzen?
Ich habe noch zig Stellen im Code, an denen IOResult nicht ausgewertet wird.

himitsu 11. Jul 2023 14:14

AW: E/A Fehler 103 beim Assignfile
 
Kann es sein, dass vor dem AssignFile diese Datei-Variable einen "komischen" uninitialisierten Zustand besitzt?

Bist du dir sicher, dass der Fehler 103 wirklich aus dem AssignFile kam? (das kann eigentlich nicht sein)
[edit] Jupp, wie du schon sagtest, es gab vorher wo anders einen "letzten" Fehler,



IOResult ist immer der "letzte" Fehler, nicht der Status der letzten Ausführung.
Wenn etwas erfolgreich war, dann wird IOResult nicht auf 0 esetzt .... das müsstest du vorher selber machen.
Also genau das selbe Verhalten, wie beim GetLastError (auch wenn hier manche/zuviele Funktionen im Erfolgsfall es "bösartig" auf 0 setzen), und deswegen darf man es immer nur abfragen, wenn die Funktion vorher "Fehler" gesagt hat (niemals im Erfolgsfall).

AssignFile macht noch keine Dateizugriffe
und es liefert nur einen Fehler 3, wenn der übergebene Dateiname zu lang ist (MAX_PATH).



PS: Wie wäre es, wenn du dich von diesen "veralteten" Pascal-Funkionen verabschiedes und z.B. auf Streams umsteigst, oder auf anderes Objektorientiertes?

Uwe Raabe 11. Jul 2023 14:27

AW: E/A Fehler 103 beim Assignfile
 
Du hast zwar den Fehler nach Rewrite mit dem Abruf von IOResult gelöscht, aber das CloseFile produziert dann eben einen weiteren Fehler, den du dann aber auch mit IOResult zurücksetzen solltest. Oder das CloseFile nach einem fehlgeschlagenen Rewrite eben gar nicht erst aufrufen.

TM6 11. Jul 2023 18:21

AW: E/A Fehler 103 beim Assignfile
 
Zitat:

Zitat von himitsu (Beitrag 1524445)
[S]
PS: Wie wäre es, wenn du dich von diesen "veralteten" Pascal-Funkionen verabschiedes und z.B. auf Streams umsteigst, oder auf anderes Objektorientiertes?

Wenn man dazu Zeit hätte... Es sind halt nicht nur ein paar Tausend Zeilen Code.
Ein "die Zeit muss man sich nehmen" hilft da leider auch nicht weiter.
Priorität dafür wäre aktuell gegen 0.
Aber ich schreibe es mir auf die Agenda.

Noch einmal Danke für die Hilfe und Erklärungen.

Edit:
Ich habe jetzt doch nochmal an vielen Stellen den Code untersucht. Die eigentlichen Schreibroutinen laufen fast immer über tFileStream ab.
Es handelte sich fast nur um vorgelagerten alten Code, um den Schreibzugriff vorab zu überprüfen. Eigentlich nicht einmal notwendig.

TM6 12. Jul 2023 10:33

AW: E/A Fehler 103 beim Assignfile
 
Hat zwar nicht direkt mit dem Thema zu tun, ist aber eine Folge einiger Tests.

Wenn ich hier eine Exception auslöse

Code:
try
  FileStream := TFileStream.Create( Path, fmCreate );
except
  ..
end;
dann erhalte ich eine "Benachrichtigung über Debugger-Exception" von Delphi.
Diese kann ich zwar pauschal über "Diesen Exception-Typ ignorieren" ausschalten. Aber nur pauschal.
Ist es eigentlich möglich, dies nur an bestimmten Stellen zu ignorieren?
Über $ irgendwas?

Möglicherweise war das der Grund der weiteren Nutzung von Assignfile, rewrite, ...

himitsu 12. Jul 2023 12:29

AW: E/A Fehler 103 beim Assignfile
 
Nein.

Es gibt Addons, wo man z.B. auch auf den Message-Text filtern kann, also nicht nur auf die Exception-Klasse.

ansonsten
https://www.delphipraxis.net/211220-...markieren.html
https://quality.embarcadero.com/browse/RSP-18827

zusätzlich
https://quality.embarcadero.com/browse/RSP-41311



Das als Grund dafür, neeeeeeeeeee? :angle2:

MSDN-Library durchsuchenCreateFile und das dann in ein Delphi-Referenz durchsuchenTHandleStream.

Via Ableitung oder per Class-Helper kann man es sich auch direkt in TFileStream oder THandleStream einfügen.


Alle Zeitangaben in WEZ +1. Es ist jetzt 09:45 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