std::inplace_vector<T,N>::append_range
来自cppreference.com
< cpp | container | inplace vector
template< container-compatible-range<T> R > constexpr void append_range( R&& rg ); |
(C++26 起) | |
以非逆序插入范围 rg 的各元素的副本到 end()
之前。
rg 中的每个迭代器均恰好被解引用一次。
参数
rg | - | 容器兼容范围,即各元素可以转换为 T 的 input_range
|
类型要求 | ||
-T 必须为从 *ranges::begin(rg) 可就位构造 (EmplaceConstructible) 到 inplace_vector 。否则,行为未定义。
|
返回值
(无)
复杂度
与 rg 的大小呈线性。对 T
构造函数的调用次数恰好等于 std::ranges::size(rg))。
异常
如果 std::ranges::size(rg) > N,抛出 std::bad_alloc。
如果由除了 T
的复制构造函数、移动构造函数、复制赋值运算符或移动赋值运算符,或者 InputIterator
的任何操作之外抛出了异常,则没有效果。
否则,如果出现异常,则 size() >= n 和范围 [
0,
n)
中的元素不会被修改,其中 n
是本次调用前 size()
的值。
示例
运行此代码
#include <cassert> #include <inplace_vector> #include <iostream> int main() { using I = std::inplace_vector<int, 8>; auto head = I{1, 2, 3, 4}; const auto tail = {-5, -6, -7}; head.append_range(tail); assert(head.size() == 7 and (head == I{1, 2, 3, 4, -5, -6, -7})); try { head.append_range(tail); // throws: no space } catch(const std::bad_alloc&) { std::cout << "std::bad_alloc\n"; } }
输出:
std::bad_alloc
参阅
尝试添加元素的范围到末尾 (公开成员函数) | |
插入一个元素范围 (公开成员函数) | |
将元素添加到容器末尾 (公开成员函数) | |
在容器末尾原位构造元素 (公开成员函数) |