Namespaces
Variants

std:: wmemset

From cppreference.net
Определено в заголовочном файле <cwchar>
wchar_t * wmemset ( wchar_t * dest, wchar_t ch, std:: size_t count ) ;

Копирует широкий символ ch в каждую из первых count позиций массива широких символов, на который указывает dest .

Если происходит переполнение, поведение не определено.

Если count равен нулю, функция ничего не делает.

Содержание

Параметры

dest - указатель на массив широких символов для заполнения
ch - заполняющий широкий символ
count - количество широких символов для заполнения

Возвращаемое значение

Возвращает копию dest .

Примечания

Эта функция не зависит от локали и не обращает внимания на значения объектов wchar_t которые она записывает: нулевые символы, а также недопустимые широкие символы также записываются.

Пример

#include <clocale>
#include <cwchar>
#include <iostream>
#include <locale>
int main()
{
    wchar_t ar[4] = {L'1', L'2', L'3', L'4'};
    std::wmemset(ar, L'\U0001f34c', 2); // заменяет [12] на 🍌 бананы
    std::wmemset(ar + 2, L'蕉', 2); // заменяет [34] на 蕉 бананы
    std::setlocale(LC_ALL, "en_US.utf8");
    std::wcout.imbue(std::locale("en_US.utf8"));
    std::wcout << std::wstring(ar, 4) << '\n';
}

Возможный вывод:

🍌🍌蕉蕉

Смотрите также

заполняет буфер символом
(функция)
копирует определённое количество широких символов между двумя неперекрывающимися массивами
(функция)
копирует-присваивает заданное значение N элементам в диапазоне
(шаблон функции)