std::queue<T,Container>::push_range
来自 cppreference.com
template< container-compatible-range<value_type> R > void push_range( R&& rg ); |
(自 C++23 起) | |
将 rg 中每个元素的副本插入到 queue
中,如同通过
- c.append_range(std::forward<R>(rg)) 如果这是一个有效的表达式(即底层容器 c 具有相应的
append_range
成员函数),或者 - ranges::copy(rg, std::back_inserter(c)) 否则。
范围内 rg 的每个迭代器都只解除引用一次。
内容 |
[编辑] 参数
rg | - | 一个 兼容容器的范围,即一个 input_range ,其元素可转换为 T |
[编辑] 返回值
(无)
[编辑] 复杂度
与 c.append_range 或 ranges::copy(rg, std::back_inserter(c))(取决于内部使用哪个函数)的复杂度相同。
[编辑] 注释
特性测试 宏 | 值 | Std | 特性 |
---|---|---|---|
__cpp_lib_containers_ranges |
202202L | (C++23) | 支持范围的 构造和插入 |
[编辑] 示例
运行此代码
#include <algorithm> #include <iostream> #include <ranges> #include <queue> template<typename Adaptor> requires (std::ranges::input_range<typename Adaptor::container_type>) void println(auto, const Adaptor& adaptor) { struct Container : Adaptor // gain access to protected Adaptor::Container c; { auto const& container() const { return this->c; } }; for (auto const& elem : static_cast<const Container&>(adaptor).container()) std::cout << elem << ' '; std::cout << '\n'; } int main() { std::queue<int> adaptor; const auto rg = {1, 3, 2, 4}; #ifdef __cpp_lib_containers_ranges adaptor.push_range(rg); #else std::ranges::for_each(rg, [&adaptor](auto e){ adaptor.push(e); }); #endif println("{}", adaptor); }
输出
1 3 2 4
[编辑] 参见
在末尾插入元素 (公有成员函数) |