std::stack<T,Container>::push_range
來自 cppreference.com
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 | - | 一個容器兼容範圍,即一個其元素可轉換為 T 的input_range 。 |
[編輯] 複雜度
與 c.append_range 或 ranges::copy(rg, std::back_inserter(c)) 的複雜度相同(取決於內部使用的函式)。
[編輯] 注意
特性測試宏 | 值 | 標準 | 特性 |
---|---|---|---|
__cpp_lib_containers_ranges |
202202L |
(C++23) | 範圍感知(Ranges-aware)構造和插入 |
[編輯] 示例
執行此程式碼
#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]
[編輯] 參見
在棧頂插入元素 (public member function) |