std::wmemcpy
来自 cppreference.com
定义在头文件 <cwchar> 中 |
||
wchar_t* wmemcpy( wchar_t* dest, const wchar_t* src, std::size_t count ); |
||
从由 src 指向的宽字符数组中复制 count 个连续的宽字符到由 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); // 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'; }
可能的输出
Wide array contains: नमस्ते\0Բարև\0
[编辑] 参见
从一个字符串复制一定数量的字符到另一个字符串 (函数) | |
在两个可能重叠的数组之间复制一定数量的宽字符 (函数) | |
C 文档 对于 wmemcpy
|