![]() |
CreateFileW richtig verwenden
Ich bin in den Geschmack gekommen CreateFileW zu verwenden.
Jetzt stelle sich mir nur die Frage, wie ich das richtig verwende und die beste Performance raushole. Aktuelle verwende ich es so
Delphi-Quellcode:
Kann man hier noch etwas besser machen?_Handle := CreateFileW(FileName, GENERIC_READ, 0, nil, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0); // für Dateien zu lesen // oder _Handle := CreateFileW(FileName, GENERIC_WRITE, FILE_SHARE_READ, nil, CREATE_ALWAYS, 0); // für Dateien zu schreiben (zb blockwrite) |
AW: CreateFileW richtig verwenden
Was willst du besser machen?
Erstmal ist es "richtig" so, abgesehn von vielleicht "FileName" ... Wie ist das deklariert? Nja, und was meinst du mit Performance, bzw. was willst du erreichen? Die API betreffend: Non-Buffered (FILE_FLAG_NO_BUFFERING, FILE_FLAG_WRITE_THROUGH) Asynchron (FILE_FLAG_OVERLAPPED) Zugriffsmuster (FILE_FLAG_RANDOM_ACCESS oder FILE_FLAG_SEQUENTIAL_SCAN) Ansonsten hat Performance erstmal rein garnichts mit CreateFile zu tun, sondern mit der Art des Zugriffs (was und wieviel wird wie gelesen/geschrieben), also prizipiell ist es egal oder CreateFile, TFileStream oder sonstwas. Zitat:
Und ansonsten hängt es von den Lese-/Schreibzugriffen ab, ob, wo und wie man was verbessern könnte. Du hast doch natürlich schon lange die zum Thema gehörenden Dokumentationen gelesen und verstanden? ![]() Wieso "Geschmack" und was ist deiner Meinung an CreateFile besser, als an TFileStream.Create, TFile.ReadXyz, TFile.WriteXyz und allem Anderen? Denn die wenigen Zeilen da oben haben grunsätzlich erstmal keinerlei Vorteile, so wie sie sind. |
AW: CreateFileW richtig verwenden
CreateFileW funktioniert genauso wie CreateFile. Wobei CreateFile ein Alias ist für CreateFileA bzw. CreaterFileW, je nach dem was man für einen Zeichensatz benutzt. Wobei CreateFileA von Windows intern nach CreateFileW gemappt wird. CreateFileA ist unter Windows mittlerweile nur noch eine leere Funktion.
Und was spricht gegen die Wrapper von der VCL? Warum alles von Hand machen? TFileStream. TMemoryStream. Stringlisten usw. |
AW: CreateFileW richtig verwenden
Zitat:
Wenn ich OPEN_EXISTING or FILE_FLAG_NO_BUFFERING statt OPEN_EXISTING verwende, ist der Zugriff 10x schneller. Zitat:
|
AW: CreateFileW richtig verwenden
Zitat:
Wäre nicht das erste mal dass sich Leute davor drücken weil sie "damals" CreateFile/BlockRead/BlockWrite gelernt haben ;) |
AW: CreateFileW richtig verwenden
Ich weiß so ungefähr wie TFileStream anzuwenden ist.
Aber warum nun vom alten Code weggehen, wenn er perfekt funktioniert und das sogar schnell :P |
AW: CreateFileW richtig verwenden
Zitat:
|
AW: CreateFileW richtig verwenden
Zitat:
Windows hat FILE_FLAG_RANDOM_ACCESS als Vorauswahl. Wenn man Dateien sequentiell verarbeitet, dann kann man theoretisch Windows sagen, dass es den WindowsFileCache verwalten anpassen soll. Wenn man aber keine Gigabyte oder mehr in der Datei umherschaufelt, hat es praktisch keinerlei spürbaren Einfluss. Und gerade bei Non-Buffered wird es umstöndlich, da du dann nur noch in Schreib-/Lesevorgänge mit "ganzen" Sektoren (am Besten aber eher ganze Cluster und Verwaltungseinheiten in der WindowsFileCache) verwenden darfst, ansonsten knallt es. Zugriffe auf kleinere Blöcke müsstest du dann erst mit einem eigenen Cache abfangen. Der Witz ist, dass NonBuffered für kleine Dateien langsamer ist, da deine Anwendung auf das Ende der Operation warten muß und eben nicht den WFC verwenden kann, der standardmäßig immer aktiv ist. |
AW: CreateFileW richtig verwenden
Also so wie immer, solange Du weißt was Du tust, ist es egal was Du tust.
Nur wenn Du glaubst Du wüßtest was Du tust....:mrgreen: Gruß K-H |
AW: CreateFileW richtig verwenden
Ich glaube ich bleibe dann einfach bei obigen Zeilen.
Eine letzte Frage aber noch. Wo müsste ich FILE_FLAG_NO_BUFFERING einfügen, wenn ich es verwenden möchte? Muss das durch FILE_ATTRIBUTE_NORMAL ersetzt werden? |
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:58 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