Maison > Article > développement back-end > Pourquoi la conversion d'un tableau de caractères en wchar_t entraîne-t-elle un comportement non défini dans ce code ?
Convertir char en wchar_t : Explorer les solutions et résoudre les erreurs de fonction
Conversion d'un tableau de caractères (char ) en un large tableau de caractères (wchar_t) est une tâche courante dans la programmation UNICODE. Bien que diverses approches existent, nous nous concentrerons sur une implémentation spécifique qui a rencontré un problème.
L'extrait de code présenté :
<code class="C++">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>
est destiné à effectuer la conversion en allouant un wchar_t local buffer, wc, de la même taille que la chaîne de caractères d'entrée. Cependant, cette approche ne fonctionne pas comme prévu.
Le problème vient du fait que wc est déclaré comme variable locale au sein de la fonction. Une fois l'appel de fonction terminé, la mémoire allouée à wc sera libérée, ce qui entraînera un comportement indéfini.
Pour résoudre ce problème, nous devons nous assurer que le tampon wchar_t alloué persiste au-delà de la durée de vie de la fonction. Le correctif approprié est :
<code class="C++">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>
En allouant le tampon wchar_t à l'aide de new, nous réservons de la mémoire sur le tas qui ne sera pas libérée au retour de la fonction. Cependant, la responsabilité de désallouer cette mémoire incombe désormais au code appelant pour éviter une fuite 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!