Namespaces
Variants

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