名前空間
変種
操作

std::stack の推論ガイド

From cppreference.com
< cpp‎ | コンテナ‎ | stack
 
 
 
 
ヘッダ <stack> で定義
template< class Container >

stack( Container )

    -> stack<typename Container::value_type, Container>;
(1) (C++17以降)
template< class Container, class Alloc >

stack( Container, Alloc )

    -> stack<typename Container::value_type, Container>;
(2) (C++17以降)
template< class InputIt >

stack( InputIt, InputIt )

    -> stack<typename std::iterator_traits<InputIt>::value_type>;
(3) (C++23から)
template< class InputIt, class Alloc >

stack( InputIt, InputIt, Alloc )
    -> stack<typename std::iterator_traits<InputIt>::value_type,

       std::deque<typename std::iterator_traits<InputIt>::value_type, Alloc>>;
(4) (C++23から)
template< ranges::input_range R >

stack( std::from_range_t, R&& )

    -> stack<ranges::range_value_t<R>>;
(5) (C++23から)
template< ranges::input_range R, class Allocator >

stack( std::from_range_t, R&&, Allocator )
    -> stack<ranges::range_value_t<R>,

       std::deque<ranges::range_value_t<R>, Allocator>>;
(6) (C++23から)

これらの推論ガイドは、基底となるコンテナの型から推論できるように、stack に対して提供されています。

1) 引数から基底となるコンテナの型を推論します。
2) (1) と同じですが、アロケータが提供されます。
3) イテレータから要素の型を推論します。基底となるコンテナの型として std::deque<typename std::iterator_traits<InputIt>::value_type> を使用します。
4) (3) と同じですが、アロケータが提供されます。
5) std::from_range_t タグと input_range から要素の型を推論します。
6) (5) と同じですが、アロケータが提供されます。

これらのオーバーロードは、以下の場合にのみオーバーロード解決に参加します。

  • InputIt (存在する場合) は LegacyInputIterator を満たします。
  • Container (存在する場合) は Allocator を満たしません。
  • (3)(C++23 まで)(4)(C++23 以降) の場合、AllocAllocator を満たし、
  • std::uses_allocator_v<Container, Alloc> は、ContainerAlloc の両方が存在する場合に true になります。

注: ライブラリが型を LegacyInputIterator を満たさないと判断する範囲は未指定です。ただし、最低限として、整数型は入力イテレータとして適格ではありません。同様に、型が Allocator を満たさないと判断する範囲は未指定です。ただし、最低限として、メンバ型 Alloc::value_type が存在し、式 std::declval<Alloc&>().allocate(std::size_t{}) が評価されないオペランドとして妥当であることが必要です。

[編集] 注記

機能テストマクロ 規格 機能
__cpp_lib_adaptor_iterator_pair_constructor 202106L (C++23) std::queue および std::stack のイテレータペアコンストラクタ。オーバーロード (2) および (4)
__cpp_lib_containers_ranges 202202L (C++23) レンジ対応の構築および挿入。オーバーロード (5) および (6)

[編集]

#include <stack>
#include <vector>
 
int main()
{
    std::vector<int> v = {1, 2, 3, 4};
    std::stack s{v}; // guide #1 deduces std::stack<int, vector<int>>
}
English 日本語 中文(简体) 中文(繁體)