Пространства имён
Варианты
Действия

std::basic_string<CharT,Traits,Allocator>::assign_range

Материал из cppreference.com
 
 
 
std::basic_string
Функции-элементы
Доступ к элементам
Итераторы
Ёмкость
Операции
Поиск
Константы
Правила вывода (C++17)
Функции, не являющиеся элементами
Ввод/Вывод
Сравнение
(до C++20)(до C++20)(до C++20)(до C++20)(до C++20)(C++20)
Числовые преобразования
(C++11)(C++11)(C++11)
(C++11)(C++11)
(C++11)(C++11)(C++11)
(C++11)
(C++11)
Вспомогательные классы
 
<tbody> </tbody>
template< container-compatible-range<CharT> R > constexpr std::basic_string& assign_range( R&& rg );
(начиная с C++23)

Заменяет содержимое строки значениями в диапазоне rg.

Эквивалентно

return assign(
    std::basic_string(
        std::from_range,
        std::forward<R>(rg),
        get_allocator())
);

Параметры

rg no section name

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

*this

Сложность

Линейная по размеру rg.

Исключения

Если операция приведёт к size() > max_size(), генерирует std::length_error.

Если по какой-либо причине генерируется исключение, эта функция не имеет эффекта (строгая гарантия безопасности исключений).

Примечание

Макрос Тестирования функциональности Значение Стандарт Функциональность
__cpp_lib_containers_ranges 202202L (C++23) функции-элементы, которые принимают no section name

Пример

#include <cassert>
#include <string>

int main()
{
    const auto source = {'s', 'o', 'u', 'r', 'c', 'e'};
    std::string destination{"destination"};

 
#ifdef __cpp_lib_containers_ranges
    destination.assign_range(source);
#else
    destination.assign(source.begin(), source.end());
#endif

    assert(destination == "source");
}

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

присваивает символы строке
(public функция-элемент) [править]
присваивает значения строке
(public функция-элемент) [править]
создаёт basic_string
(public функция-элемент) [править]