Heim >Backend-Entwicklung >C++ >Warum führt die Konvertierung von char in wchar_t in meiner Unicode-Anwendung zu undefiniertem Verhalten?
So konvertieren Sie char in wchar_t für die Unicode-Integration
Problem:
Entwickler können beim Konvertieren von char auf Probleme stoßen wchar_t in Unicode-Anwendungen. Das folgende Codebeispiel veranschaulicht einen häufigen Fehler:
<code class="cpp">const wchar_t *GetWC(const char *c) { const size_t cSize = strlen(c)+1; wchar_t wc[cSize]; mbstowcs (wc, c, cSize); return wc; }</code>
Antwort:
Das Problem tritt auf, weil wc eine lokale Variable ist, deren Zuordnung aufgehoben wird, wenn die Funktion zurückkehrt. Dies führt zu undefiniertem Verhalten. Der richtige Ansatz besteht darin, wc dynamisch mit new zuzuweisen und sicherzustellen, dass der aufrufende Code den Speicher freigibt:
<code class="cpp">const wchar_t *GetWC(const char *c) { const size_t cSize = strlen(c)+1; wchar_t* wc = new wchar_t[cSize]; mbstowcs (wc, c, cSize); return wc; }</code>
Hinweis: Um dies zu vermeiden, muss der aufrufende Code für die Freigabe des zugewiesenen Speichers verantwortlich sein Speicherlecks.
Das obige ist der detaillierte Inhalt vonWarum führt die Konvertierung von char in wchar_t in meiner Unicode-Anwendung zu undefiniertem Verhalten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!