Namespaces
Variants

std::inplace_vector<T,N>:: assign_range

From cppreference.net

template < container-compatible-range < T > R >
constexpr void assign_range ( R && rg ) ;
(начиная с C++26)

Заменяет элементы в контейнере копией каждого элемента из rg .

Каждый итератор в диапазоне rg разыменовывается ровно один раз.

Если rg пересекается с * this , поведение не определено.

Содержание

Параметры

rg - an input_range с типом ссылки, преобразуемым в тип элемента контейнера
Требования к типам
-
Если std:: assignable_from < T & , ranges:: range_reference_t < R >> не выполняется, программа некорректна.
-
Если T не является EmplaceConstructible в inplace_vector из * ranges:: begin ( rg ) , поведение не определено.

Исключения

  • std::bad_alloc , если std :: ranges:: distance ( rg ) > capacity ( ) .
  • Любое исключение, выброшенное при инициализации вставляемого элемента.

Пример

#include <algorithm>
#include <cassert>
#include <initializer_list>
#include <inplace_vector>
#include <iostream>
#include <new>
int main()
{
    const auto source = {1, 2, 3};
    std::inplace_vector<int, 4> destination{4, 5};
    destination.assign_range(source);
    assert(std::ranges::equal(destination, source));
    try
    {
        const auto bad = {-1, -2, -3, -4, -5};
        destination.assign_range(bad); // выбрасывает исключение: bad.size() > destination.capacity()
    }
    catch(const std::bad_alloc& ex)
    {
        std::cout << ex.what() << '\n';
    }
}

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

std::bad_alloc

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

вставляет диапазон элементов
(публичная функция-член)
добавляет диапазон элементов в конец
(публичная функция-член)
присваивает значения контейнеру
(публичная функция-член)
присваивает значения контейнеру
(публичная функция-член)