std:: wmemcpy
|
Défini dans l'en-tête
<cwchar>
|
||
|
wchar_t
*
wmemcpy
(
wchar_t
*
dest,
const
wchar_t
*
src,
std::
size_t
count
)
;
|
||
Copie exactement count caractères larges successifs du tableau de caractères larges pointé par src vers le tableau de caractères larges pointé par dest . Si les objets se chevauchent, le comportement est indéfini. Si count est zéro, la fonction ne fait rien.
Table des matières |
Paramètres
| dest | - | pointeur vers le tableau de caractères larges à copier |
| src | - | pointeur vers le tableau de caractères larges à copier |
| count | - | nombre de caractères larges à copier |
Valeur de retour
dest
Notes
L'équivalent de cette fonction pour les chaînes d'octets est std::strncpy , et non std::strcpy .
Cette fonction n'est pas sensible aux paramètres régionaux et ne prête aucune attention aux valeurs des wchar_t qu'elle copie : les caractères nuls ainsi que les caractères non valides sont également copiés.
Exemple
#include <clocale> #include <cwchar> #include <iostream> #include <iterator> #include <locale> int main(void) { const wchar_t from1[] = L"नमस्ते"; const wchar_t from2[] = L"Բարև"; const std::size_t sz1 = std::size(from1); const std::size_t sz2 = std::size(from2); wchar_t to[sz1 + sz2]; std::wmemcpy(to, from1, sz1); // copie from1, avec son terminateur nul std::wmemcpy(to + sz1, from2, sz2); // ajoute from2, avec son terminateur nul std::setlocale(LC_ALL, "en_US.utf8"); std::wcout.imbue(std::locale("en_US.utf8")); std::wcout << L"Wide array contains: "; for (std::size_t n = 0; n < std::size(to); ++n) if (to[n]) std::wcout << to[n]; else std::wcout << L"\\0"; std::wcout << L'\n'; }
Sortie possible :
Wide array contains: नमस्ते\0Բարև\0
Voir aussi
|
copie un certain nombre de caractères d'une chaîne à une autre
(fonction) |
|
|
copie un certain nombre de caractères larges entre deux tableaux, potentiellement chevauchants
(fonction) |
|
|
Documentation C
pour
wmemcpy
|
|