std:: wmemcpy
|
Definido en el encabezado
<cwchar>
|
||
|
wchar_t
*
wmemcpy
(
wchar_t
*
dest,
const
wchar_t
*
src,
std::
size_t
count
)
;
|
||
Copia exactamente count caracteres anchos sucesivos desde el array de caracteres anchos apuntado por src al array de caracteres anchos apuntado por dest . Si los objetos se superponen, el comportamiento es indefinido. Si count es cero, la función no hace nada.
Contenidos |
Parámetros
| dest | - | puntero al array de caracteres anchos al que copiar |
| src | - | puntero al array de caracteres anchos desde el que copiar |
| count | - | número de caracteres anchos a copiar |
Valor de retorno
dest
Notas
El análogo de esta función para cadenas de bytes es std::strncpy , no std::strcpy .
Esta función no es sensible a la configuración regional y no presta atención a los valores de los wchar_t objetos que copia: los nulos así como los caracteres inválidos también se copian.
Ejemplo
#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); // copiar from1, junto con su terminador nulo std::wmemcpy(to + sz1, from2, sz2); // añadir from2, junto con su terminador nulo 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'; }
Salida posible:
Wide array contains: नमस्ते\0Բարև\0
Véase también
|
copia una cierta cantidad de caracteres de una cadena a otra
(función) |
|
|
copia una cierta cantidad de caracteres anchos entre dos arreglos, posiblemente superpuestos
(función) |
|
|
Documentación de C
para
wmemcpy
|
|