std:: wmemcpy
From cppreference.net
|
定义于头文件
<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); // 复制 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
for
wmemcpy
|
|