AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

TFileStream.Create vs. FileCreate

Ein Thema von Incocnito · begonnen am 10. Mai 2023 · letzter Beitrag vom 12. Mai 2023
Antwort Antwort
Incocnito

Registriert seit: 28. Nov 2016
230 Beiträge
 
#1

AW: TFileStream.Create vs. FileCreate

  Alt 10. Mai 2023, 13:07
Ich kann irgendwie noch nicht verstehen, wie die repeat Schleife im INVALID_HANDLE_VALUE Fall funktionieren soll, wenn sie mit until (True) abgeschlossen wird.
Jaaa, ist ja richtig 😅. Habe das auf while(True)... umgebaut. Mag ich eh lieber als repeat...until(false). 😉

Du kannst im debugger auch nur bei bestimmten exceptions anhalten lassen.
Ich glaube, das weiß er:
Eine Möglichkeit wäre es disen Exception-Typ zu ignorieren, aber das finde ich noch bescheuerter.
Exakt 😁

Erst mit MSDN-Library durchsuchenCreateFile versuchen die Datei zu öffnen
und wenn erfolgreich in ein Delphi-Referenz durchsuchenTHandleStream.

Der Rückgabewert der Funktion als TStream ist sowieso optimaler. (egal was für eine Klasse letzendlich drin steckt)
Ich möchte das lieber nicht ändern, ich finde die TFileStream-Geschichte eh nicht so schön, aber da mein Aufruf da Panik
produziert hat habe ich nun eh Verbot da was einzubauen / zu ändern. Ich hätte nur gerne verstanden warum das nun so eskaliert ist.

Das in den 10 ms zwischen FileClose und TFileStream.Create jemand zwischen grätschen kann ist mir hierfür tatsächlich total egal,
weil vernachlässigbar. Dann greift halt das "alte" Try-Except, was vorher schon da war.
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.706 Beiträge
 
Delphi 12 Athens
 
#2

AW: TFileStream.Create vs. FileCreate

  Alt 10. Mai 2023, 13:18
Ich hätte nur gerne verstanden warum das nun so eskaliert ist.
Nun ja, mit der oben gezeigten repeat-until-True Schleife (die ja eigentlich keine ist) wird entweder sofort oder nach 200ms das TFileStream.Create aufgerufen. Damit muss der Defender in kürzester Zeit zweimal ran. Das PreCheck löst also nicht das Problem, sondern macht es nur schlimmer.

Wenn du nur Probleme mit der Debugger-Exception hast, dann klammere deine (hoffentlich korrigierte) Lösung doch einfach in ein {$IFDEF DEBUG} . Dann hast du Ruhe und der Kunde bekommt davon nichts mit.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Incocnito

Registriert seit: 28. Nov 2016
230 Beiträge
 
#3

AW: TFileStream.Create vs. FileCreate

  Alt 11. Mai 2023, 08:44
Leider wird das Debug-Compilat bei unseren Anwendungen für etwas anderes verwendet.

Die Idee mit dem THandleStream sag gut aus, aber leider gibt der das Handle nicht mehr selbstständig frei.

Jetzt haben die Kollegen hier zeitgleich auch noch in Massen Sachen gebaut, bei dem es in einer Tour zu
Debugger-Exceptions kommt. Mir bleibt ja eh nichts als die jetzt wie alle anderen zu deaktivieren.
Fehlersuchen werden (für mich zumindest) damit nochmal eine ganze Ecke schwieriger.

Um dem Ganzen noch einen drauf zu setzen: Wenn ich mit meiner Funktion das FileCreate "nur" verdoppel,
funktioniert das Tray-Icon vom Programm nicht mehr (er reagiert nicht mehr auf OnClick).
Ich glaube ich mache eine Umschulung als Blumengießer, das ist mir zu hoch.
  Mit Zitat antworten Zitat
freimatz

Registriert seit: 20. Mai 2010
1.496 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: TFileStream.Create vs. FileCreate

  Alt 11. Mai 2023, 10:18
Debugger-Exceptions? Was ist das?
Verwendet ihr nicht spezifische Exception für unterschiedliche Fälle? Man kann dann genau diese Fälle im Debugger deaktivieren.
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.706 Beiträge
 
Delphi 12 Athens
 
#5

AW: TFileStream.Create vs. FileCreate

  Alt 11. Mai 2023, 10:26
Debugger-Exceptions? Was ist das?
Das sind Exceptions, die nur im Debugger angezeigt werden, in der Applikation aber entsprechend behandelt sind, so dass der User nichts davon mitbekommt.

Das mit dem Deaktivieren ist so eine Sache. An manchen Stellen möchte man vielleicht eine EFileNotFoundException nicht sehen, weil sie gefühlt zigmal auftritt und im except ja behandelt wird, an anderen Stellen möchte man den Debugger aber eben doch anhalten lassen.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Incocnito

Registriert seit: 28. Nov 2016
230 Beiträge
 
#6

AW: TFileStream.Create vs. FileCreate

  Alt 11. Mai 2023, 10:32
Debugger-Exceptions? Was ist das?
Verwendet ihr nicht spezifische Exception für unterschiedliche Fälle? Man kann dann genau diese Fälle im Debugger deaktivieren.
Ich wollte sprachlich nur unterscheiden zwischen den Exceptions, die der Kunde angezeigt bekommt
(weil es kein Try-Except gibt) ["Laufzeit-Exceptions" oder einfach nur "Exceptions"] und denjenigen,
die "wohl mal kommen können" und dann mit Try-Except abgefangen wurden, somit zum Kunden nicht durchschlagen ["Debugger-Exceptions"].
Zumindest verwenden ich und die Entwickler mit denen ich zusammen arbeite das immer so. Kein Anspruch auf Richtigkeit.

Im Konkreten Fall bekomme ich die gleiche File-Access-Everything-Burns-Meldung vom FileCreate für die LockDatei (wo das halt mal passieren kann)
und halt für irgendwelche anderen Dateien, wo ich (wie gesagt, amit stehe ich hier wohl alleine da) schon konkreter wissen wollen würde,
dass da gerade irgendwas schief geht.

Edit: ... Ja, genau, was Uwe sagt!
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
10.005 Beiträge
 
Delphi 12 Athens
 
#7

AW: TFileStream.Create vs. FileCreate

  Alt 11. Mai 2023, 11:47
Die Idee mit dem THandleStream sag gut aus, aber leider gibt der das Handle nicht mehr selbstständig frei.
Es spricht ja nichts dagegen, eine eigene abgeleitete Klasse zu erstellen, die das anders regelt.
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.706 Beiträge
 
Delphi 12 Athens
 
#8

AW: TFileStream.Create vs. FileCreate

  Alt 11. Mai 2023, 12:01
Dann würde ich vermutlich eher von TFileStream ableiten und die Überprüfung im Create gleich einbauen.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.415 Beiträge
 
Delphi 12 Athens
 
#9

AW: TFileStream.Create vs. FileCreate

  Alt 11. Mai 2023, 12:32
Falls nicht irgendwo nachfolgend "explizit" Funktionen des TFileStream verwendet werden, spricht nichts dagegen die Variablen/Parameter als TStream zu deklarieren.
Dann ist es auch egal, ob TFileSteam, THandleStream, TMemoryStream oder ein anderer Streamnachfahre benutzt wird.

So wie man z.B. auch besser TStrings anstatt TStringList benutzt, womit es dann egal ist, ob eine StringList oder z.B. Memo.Lines beim Aufruf benutzt wird.



Leider wird das Debug-Compilat bei unseren Anwendungen für etwas anderes verwendet.
Du könntest aber auch das Debug-Profil (BuildConfig) ableiten/kopieren und darin dann die gewünschte "Bedingung" definieren. (Projektverwaltung > Build-Konfigurationen > Debug > Kontextmenü: Erzeugen)

Das {$IFDEF DEBUG} bezieht sich ja nicht auf den Profil-Name "Debug", sondern auf das DEFINE/Bedingung "DEBUG", welches im Profil steht. (Projektoptionen > Compiler > Bedingungen)

oder MSDN-Library durchsuchenIsDebuggerPresent
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu (11. Mai 2023 um 12:41 Uhr)
  Mit Zitat antworten Zitat
QuickAndDirty

Registriert seit: 13. Jan 2004
Ort: Hamm(Westf)
2.034 Beiträge
 
Delphi 12 Athens
 
#10

AW: TFileStream.Create vs. FileCreate

  Alt 12. Mai 2023, 15:34
Ich glaube ich mache eine Umschulung als Blumengießer, das ist mir zu hoch.
Du hast keine Ahnung wie unintuitiv teuer Baumrecht einem zu stehen kommen kann.
Andreas
Monads? Wtf are Monads?
  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 19:14 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