std:: wmemcpy
|
Определено в заголовочном файле
<cwchar>
|
||
|
wchar_t
*
wmemcpy
(
wchar_t
*
dest,
const
wchar_t
*
src,
std::
size_t
count
)
;
|
||
Точно копирует count последовательных широких символов из массива широких символов, на который указывает src , в массив широких символов, на который указывает dest . Если объекты перекрываются, поведение не определено. Если count равен нулю, функция ничего не делает.
Содержание |
Параметры
| dest | - | указатель на массив широких символов для копирования |
| src | - | указатель на массив широких символов для копирования из |
| count | - | количество копируемых широких символов |
Возвращаемое значение
dest
Примечания
Аналог этой функции для байтовых строк — std::strncpy , а не std::strcpy .
Эта функция не зависит от локали и не обращает внимания на значения wchar_t объектов, которые она копирует: нулевые символы, а также недопустимые символы также копируются.
Пример
#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); // копировать from1 вместе с нулевым терминатором std::wmemcpy(to + sz1, from2, sz2); // добавить from2 вместе с нулевым терминатором 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'; }
Возможный вывод:
Wide array contains: नमस्ते\0Բարև\0
Смотрите также
|
копирует определенное количество символов из одной строки в другую
(функция) |
|
|
копирует определенное количество широких символов между двумя, возможно перекрывающимися, массивами
(функция) |
|
|
C documentation
для
wmemcpy
|
|