![]() |
Unicode Eingabe einlesen
Ich versuche gerade eine Eingabe von der Konsole zu lesen:
Code:
Aber wenn er die Eingabe ausgeben soll, kommt es zu einer Zugriffsverletzung. Was mache ich da falsch? Die Eingabe soll spätermal an eine Funktion übergeben werden.
#include "stdafx.h"
#include <windows.h> #define INFO _T("Ausgabe der SIDs zu einem principal\n") #define PRINCIPAL _T("Principal (z.B. Benutzername): ") int _tmain(int argc, _TCHAR* argv[]) { PWSTR principal; wprintf(INFO); wprintf(PRINCIPAL); wscanf(L"%s", &principal); wprintf(L"%s\n", principal); getchar(); return 0; } |
Re: Unicode Eingabe einlesen
Zeile12: Welche Adresse liefert &principal?
Oben arbeitest du mit #define, vermute mal das es dadurch knallt. (ungetestet) |
Re: Unicode Eingabe einlesen
Ha! ein Abtrüniger C-Programmierer.
Die Strafe folgt sogleich:
Code:
Mit Delphi wäre das nicht passiert. :-)
PWSTR principal; // das ist nur ein Zeiger, für den niemand einen Speicherplatz reserviert hat
|
Re: Unicode Eingabe einlesen
Auch wenn ich das ändere geht es nicht. Aber so geht es:
Code:
Das ganze muss ich jetzt aber an eine Funktion übergeben: LookupAccountName die ich in einer Funktion kapseln will:
wchar_t principal[80];
wprintf(INFO); wprintf(QUERYINPUT); wscanf(L"%s", &principal); wprintf(L"%s\n", principal); getchar(); return 0; Das soll dann so aussehen:
Code:
Bekomme aber noch zwei Fehlermeldungen:
DWORD GetStrSID(LPTSTR server, LPTSTR principal, wchar_t *StrSID)
{ wprintf(principal); // SID ermitteln und in lesbare Form umwandeln // in StrSID zurückgeben return GetLastError(); } int _tmain(int argc, _TCHAR* argv[]) { wchar_t principal[80]; wchar_t *StrSID; int LastError; wprintf(INFO); wprintf(QUERYINPUT); wscanf(L"%s", &principal); wprintf(L"%s\n", principal); LastError = GetStrSID(NULL, principal, StrSID); if (LastError == 0) { wprintf(L"%s", StrSID); } else { wprintf("%i", LastError); } getchar(); return 0; } Zitat:
Zitat:
|
Re: Unicode Eingabe einlesen
Dass DWORD und int einen Unterschied machen und warum, erklaere ich jetzt nicht nochmal.
Bei
Code:
fehlt mir irgendwie der Unicode-Literal als erster Parameter. Wie waere es mit
wprintf("%i", LastError);
Code:
...?
wprintf(L"%i", LastError);
... warum du echtes Unicode mit der gemischten Form (LPTSTR) zusammen benutzt, erschliesst sich mir auch nach mehrmaligem Hingucken noch nicht ganz, aber vielleicht kannst du es erklaeren. Genau wie den Sinn gemischt Typen aus den Windows-Headern und native C++-Typen zu benutzen ... :gruebel: Wenn man _UNICODE/UNICODE nicht definiert hat, warum sollte dann bspw. die Zeile
Code:
funktionieren, wenn doch principal vom Typ LPTSTR (schon an die konstante Variante LPCTSTR gedacht?) ist und damit zu LPSTR (sprich PChar) wird?! Stattdessen solltest du eben LPWSTR oder besser LPCWSTR benutzen. Und ueberhaupt mal weniger Windowstypen und C++-Typen mischen (sprich: disziplinierter programmieren), damit es zu solchen Fehlern erst garnicht kommen kann.
wprintf(principal);
Wenn man die Adresse eines Zeichenarrays haben will, muss man auch keinen Adressoperator voranstellen. Hier meine leicht korrigierte Variante. WinDiff wirste ja haben ...
Code:
Uebrigens empfiehlt sich beim Arbeiten mit nullterminierten Strings auch das Ausnullen des Puffers (principal).
DWORD GetStrSID(LPCWSTR server, LPCWSTR principal, LPWSTR &StrSID)
{ wprintf(principal); // SID ermitteln und in lesbare Form umwandeln // in StrSID zurückgeben return GetLastError(); } int __cdecl _tmain(int argc, _TCHAR *argv[]) { WCHAR principal[80], *StrSID = principal; DWORD LastError; // wprintf(INFO); // wprintf(QUERYINPUT); <--- warum die auskommentiert sind sollte klar sein wscanf(L"%s", principal); wprintf(L"%s\n", principal); LastError = GetStrSID(NULL, principal, StrSID); if (LastError == 0) { wprintf(L"%s", StrSID); } else { wprintf(L"%i", LastError); } getchar(); return 0; } Last but not least: da du Arrays equivalent zu Pointern benutzen kannst, ist die Trennung zwischen principal und StrSID komplett hinfaellig. Beide koennen equivalent benutzt werden. Noch'n Nachtrag: Warum _tmain wenn du ohnehin komplett in Unicode arbeiten willst? Es hilft dem Compiler ungemein, wenn du ihm erklaerst was du willst :zwinker: |
Re: Unicode Eingabe einlesen
Genau mit diesem Unicode Mischmasch und mit Zeichenketten unter C/C++ habe ich ja so meine Probleme, deswegen wollte ich mir das mal genauer angucken und endlich mal verstehen.
Zum Programm: Unicode ist in den Projektoptionen eingestellt, deswegen dachte ich, ich müsste es nicht noch mal im Code definieren. Zitat:
Zitat:
Delphi-Quellcode:
Nicht wirklich. :gruebel:
// wprintf(INFO);
// wprintf(QUERYINPUT); <--- warum die auskommentiert sind sollte klar sein Zitat:
Zitat:
|
Re: Unicode Eingabe einlesen
Zitat:
Zitat:
Zitat:
Zitat:
Spaeter habe ich gesehen, dass zumindest INFO oben schon deklariert war. Aber eben nicht in dem Beitrag den ich zitiert habe. Zitat:
Zitat:
|
Re: Unicode Eingabe einlesen
Zitat:
Zitat:
Zitat:
|
Re: Unicode Eingabe einlesen
Zitat:
Zitat:
Zitat:
|
Re: Unicode Eingabe einlesen
Zum letzten Punkt: Ich meinte wie main "aussehen" muss. Bei _tmain hast du ja gesagt es "gehöre" zu TCHAR. Aber wie sieht der Einsprungspunkt aus, wen ich WCHAR verwende? Oder hab eich da jetzt einfach nur was übersehen oder falsch verstanden?
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 14:37 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