std:: wmemcpy
|
Definiert im Header
<cwchar>
|
||
|
wchar_t
*
wmemcpy
(
wchar_t
*
dest,
const
wchar_t
*
src,
std::
size_t
count
)
;
|
||
Kopiert genau count aufeinanderfolgende Breitzeichen aus dem Breitzeichen-Array, auf das src zeigt, in das Breitzeichen-Array, auf das dest zeigt. Wenn sich die Objekte überlappen, ist das Verhalten undefiniert. Wenn count null ist, führt die Funktion keine Operation aus.
Inhaltsverzeichnis |
Parameter
| dest | - | Zeiger auf das Ziel-Array von Breitzeichen |
| src | - | Zeiger auf das Quell-Array von Breitzeichen |
| count | - | Anzahl der zu kopierenden Breitzeichen |
Rückgabewert
dest
Hinweise
Das Analogon dieser Funktion für Byte-Strings ist std::strncpy , nicht std::strcpy .
Diese Funktion ist nicht lokalisierungssensitiv und beachtet nicht die Werte der wchar_t Objekte, die sie kopiert: Nullzeichen sowie ungültige Zeichen werden ebenfalls kopiert.
Beispiel
#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); // copy from1, along with its null terminator std::wmemcpy(to + sz1, from2, sz2); // append from2, along with its null terminator 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'; }
Mögliche Ausgabe:
Wide array contains: नमस्ते\0Բարև\0
Siehe auch
|
kopiert eine bestimmte Anzahl von Zeichen von einer Zeichenkette zu einer anderen
(Funktion) |
|
|
kopiert eine bestimmte Anzahl von Breitzeichen zwischen zwei, möglicherweise überlappenden, Arrays
(Funktion) |
|
|
C-Dokumentation
für
wmemcpy
|
|