std::inplace_vector<T,N>:: insert_range
|
template
<
container-compatible-range
<
T
>
R
>
constexpr iterator insert_range ( const_iterator pos, R && rg ) ; |
(начиная с C++26) | |
Вставляет, в неперевёрнутом порядке, копии элементов из rg перед pos .
| Этот раздел не завершён |
Каждый итератор в диапазоне rg разыменовывается ровно один раз.
Если rg пересекается с * this , поведение не определено.
Содержание |
Параметры
| pos | - |
итератор, перед которым будет вставлено содержимое (
pos
может быть итератором
end()
)
|
| rg | - |
совместимый с контейнером диапазон
container compatible range
, то есть
input_range
, элементы которого конвертируются в
T
|
| Требования к типам | ||
-
|
||
Возвращаемое значение
Итератор на первый элемент, вставленный в * this , или pos , если rg пуст.
Исключения
- std::bad_alloc , если ranges:: distance ( rg ) + size ( ) > capacity ( ) . Элементы * this не модифицируются.
-
Любое исключение, выброшенное при вставке (т.е. конструктором копирования/перемещения, оператором присваивания перемещением/копированием
T) или любой операцией LegacyInputIterator . Элементы * this в диапазоне[ 0 ,pos)не модифицируются.
Пример
#include <cassert> #include <inplace_vector> #include <iterator> #include <new> #include <print> int main() { auto v = std::inplace_vector<int, 8>{0, 1, 2, 3}; auto pos = std::next(v.begin(), 2); assert(*pos == 2); const auto rg = {-1, -2, -3}; v.insert_range(pos, rg); std::println("{}", v); try { assert(v.size() + rg.size() > v.capacity()); v.insert_range(pos, rg); // throws: no space } catch(const std::bad_alloc& ex) { std::println("{}", ex.what()); } }
Возможный вывод:
[0, 1, -1, -2, -3, 2, 3] std::bad_alloc
Смотрите также
|
вставляет элементы
(публичная функция-член) |
|
|
добавляет диапазон элементов в конец
(публичная функция-член) |
|
|
пытается добавить диапазон элементов в конец
(публичная функция-член) |