std::inplace_vector<T,N>::append_range
来自cppreference.com
<tbody>
</tbody>
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
参阅
| 尝试添加元素的范围到末尾 (公开成员函数) | |
| 插入元素范围 (公开成员函数) | |
| 将元素添加到容器末尾 (公开成员函数) | |
| 在容器末尾原位构造元素 (公开成员函数) |