![]() |
PWideChar oder PAnsiChar
Hallo zusammen,
meine Frage geht in eine ähnliche Richtung wie der Beitrag "String Kovertierung". Ich bin dabei meine Warnungen bezüglich impliziten Stringkonvertierungen zu überarbeiten. Dabei bin ich auf folgendes Problem gestoßen:
Delphi-Quellcode:
Gehe ich mit dem Mauszeiger auf
const
sDLL = 'Splash.dll'; var haDLL : Cardinal; procedure TintSplash.Show(sTitel: string); const sBef = 'Show'; var fShow: procedure(Titel: WideString); stdcall; begin haDLL := GetModuleHandle(PWideChar(sDLL)); { prüfen ob DLL schon geladen } if haDLL = 0 then haDLL := LoadLibrary(PWideChar(sDLL)); { DLL dynamisch laden } if haDLL <> 0 then begin @fShow := GetProcAddress(haDLL, PWideChar(sBef)); fShow(sTitel); end
Delphi-Quellcode:
bekomme ich als Hilfe
GetProcAddress
Delphi-Quellcode:
.
Windows.GetProcAddress(Cardinal,PAnsiChar)Method
Ändere ich die Zeile in
Delphi-Quellcode:
bekomme ich die Hilfe
@fShow := GetProcAddress(haDLL, sBef);
Delphi-Quellcode:
.
Windows.GetProcAddress(Cardinal,PWideChar)Method
Warum wird bei expliziter Wandlung in PWideChar PAnsiChar angezeigt und bei direkter Übergabe des String PWideChar? Muss ich in den drei Fällen oben überhaupt eine explizite Umwandlung vornehmen? In allen drei Fällen ist der übergebene Parameter eine const die automatisch als String deklariert ist. Was wäre, wenn ich sDLL als String mit übergeben würde
Delphi-Quellcode:
.
TintSplash.Show(sDLL, sTitel: string);
Danke für eine Antwort Gerd |
AW: PWideChar oder PAnsiChar
Da in den letzten Versionen von Delphi, der Typ STRING automatisch auf UNICODESTRING gesetzt wurde, werden demzufolge alle Konstanten auch automatisch Unicodestrings. Da Widestrings und Ansistrings andere Typen sind,
wird hier immer konvertiert (und damit auch eine entsprechende Warnung ausgegeben). Lösung: Benutz typisierte Konstanten und definier dabei den gewünschten String-Typ :) Beispiel:
Delphi-Quellcode:
const sDll : Widestring = 'Splash.dll';
const sBuf : widestring = 'Show'; |
AW: PWideChar oder PAnsiChar
Beispielhaft an einem Aufruf:
Delphi-Quellcode:
Wenn Du eine API-Funktion aufrufst, schau unbedingt, welcher Typ erwartet wird! Von den meisten System-APIs, die Text erwarten, gibt es auch die expliziten *A und *W-Varianten; der Aufruf ohne zeigt bis auf in Uralt-Delphis auf *W, früher auf *A.
haDLL := LoadLibrary(PChar(sDLL)); // mit sDLL: string
haDLL := LoadLibraryA(PAnsiChar(sDLL)); // mit sDLL: AnsiString haDLL := LoadLibraryW(PWideChar(sDLL)); // mit sDLL: WideString |
AW: PWideChar oder PAnsiChar
Hi,
nicht direkt eine Antwort auf deine Frage aber... Zu vielen/den meisten API Calls gibt es zwei Varianten: Ansi und Widestring. Zum Beispiel GetModuleHandleA und GetModuleHandleW. Du verwendest aber den Alias GetModuleHandle. Dann solltest du auch beim Datentyp einen Alias verwenden.
Delphi-Quellcode:
Das funktioniert wenn GetModuleHandle auf GetModuleHandleW verweist (Unicode Delphis). In älteren Versionen geht der verweis auf GetModuleHandleA und dann stimmt der Datentyp nicht mehr.
haDLL := GetModuleHandle(PWideChar(sDLL));
Delphi-Quellcode:
haDLL := GetModuleHandleW(PWideChar(sDLL)); // wenn du bewusst WideChar möchtest
haDLL := GetModuleHandleA(PAnsiChar(sDLL)); // wenn du bewusst AnsiChar möchtest // meistens bessser: haDLL := GetModuleHandle(PChar(sDLL)); // wenn der Typ egal ist Trotz rotem Kasten, da ein zwei erklärende Worte mehr... |
AW: PWideChar oder PAnsiChar
Hallo zusammen,
Danke für die Antwort. Dann stimmt ja meine obiger Code. An die typisierten Konstanten hatte ich auch schon gedacht. Drei Fragen sind aber noch offen:
Grüße Gerd |
AW: PWideChar oder PAnsiChar
Zitat:
2. Immer mit Strg+Linksklick zur eigentlichen Definition gucken und den Hint ignorieren. 3. Ja. |
AW: PWideChar oder PAnsiChar
Zitat:
Linksklick brachte aber für mich auch nicht die Sicherheit, da der trotz PWideChar auf den ersten dieser beiden Implementationen gesprungen ist.
Delphi-Quellcode:
Aber jetzt bin ich sicher, dass meine Umstellung korrekt ist
function GetProcAddress(hModule: HMODULE; lpProcName: LPCSTR): FARPROC; external kernel32 name 'GetProcAddress';
function GetProcAddress(hModule: HMODULE; lpProcName: LPCWSTR): FARPROC; Danke |
AW: PWideChar oder PAnsiChar
Spätestens seit XP endet jeder API Aufruf bei der W-Version. Selbst wenn man explizit die A-Version aufruft, Windows leitet das intern an die W-Version weiter.
|
AW: PWideChar oder PAnsiChar
Win32API-Typname = Pascal/Delphi-Typename
LPCSTR = PAnsiChar LPCWSTR = PWideChar Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:53 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 by Thomas Breitkreuz