std::stack<T,Container>::push_range
来自 cppreference.cn
template< container-compatible-range<value_type> R > void push_range( R&& rg ); |
(自 C++23 起) | |
将 rg 中每个元素的副本插入到 stack
中,如同通过
- 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 <initializer_list> #include <stack> #include <version> #ifdef __cpp_lib_format_ranges #include <print> using std::println; #else #define FMT_HEADER_ONLY #include <fmt/ranges.h> using fmt::println; #endif int main() { std::stack<int> adaptor; const auto rg = {1, 3, 2, 4}; #ifdef __cpp_lib_containers_ranges adaptor.push_range(rg); #else for (int e : rg) adaptor.push(e); #endif println("{}", adaptor); }
输出
[1, 3, 2, 4]
[编辑] 参见
在顶部插入元素 (公共成员函数) |