Maison >développement back-end >C++ >Pourquoi la conversion de char en wchar_t dans mon application Unicode entraîne-t-elle un comportement indéfini ?
Comment convertir char en wchar_t pour l'intégration Unicode
Problème :
Les développeurs peuvent rencontrer des problèmes lors de la conversion de char en wchar_t dans les applications Unicode. L'exemple de code suivant illustre une erreur courante :
<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>
Réponse :
Le problème se pose car wc est une variable locale qui est désallouée au retour de la fonction. Cela entraîne un comportement indéfini. L'approche correcte consiste à allouer wc dynamiquement en utilisant new et à s'assurer que le code appelant libère la mémoire :
<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>
Remarque : Le code appelant doit être responsable de la désallocation de la mémoire allouée pour éviter fuites de mémoire.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!