Namensräume
Varianten
Aktionen

deduction guides for std::stack

Von cppreference.com
< cpp‎ | container‎ | stack
 
 
 
 
Definiert in Header <stack>
template< class Container >

stack( Container )

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

stack( Container, Alloc )

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

stack( InputIt, InputIt )

    -> stack<typename std::iterator_traits<InputIt>::value_type>;
(3) (seit 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) (seit C++23)
template< ranges::input_range R >

stack( std::from_range_t, R&& )

    -> stack<ranges::range_value_t<R>>;
(5) (seit 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) (seit C++23)

Diese Deduktionshilfen werden für stack bereitgestellt, um die Deduktion vom zugrunde liegenden Containertyp zu ermöglichen.

1) Deduziert den zugrunde liegenden Containertyp aus dem Argument.
2) Dasselbe wie (1), nur dass der Allokator bereitgestellt wird.
3) Deduziert den Elementtyp aus dem Iterator unter Verwendung von std::deque<typename std::iterator_traits<InputIt>::value_type> als zugrunde liegendem Containertyp.
4) Dasselbe wie (3), nur dass der Allokator bereitgestellt wird.
5) Deduziert den Elementtyp aus einem std::from_range_t Tag und einem input_range.
6) Dasselbe wie (5), nur dass der Allokator bereitgestellt wird.

Diese Überladungen nehmen nur an der Auflösung von Überladungen teil, wenn

Hinweis: Das Ausmaß, in dem die Bibliothek feststellt, dass ein Typ LegacyInputIterator nicht erfüllt, ist nicht spezifiziert, außer dass ganzzahlige Typen als Minimum keine Eingabeiteratoren sind. Ebenso ist das Ausmaß, in dem sie feststellt, dass ein Typ Allocator nicht erfüllt, nicht spezifiziert, außer dass als Minimum der Mitgliedstyp Alloc::value_type existieren muss und der Ausdruck std::declval<Alloc&>().allocate(std::size_t{}) als unevaluierter Operand wohlgeformt sein muss.

[bearbeiten] Notizen

Feature-Test-Makro Wert Std Feature
__cpp_lib_adaptor_iterator_pair_constructor 202106L (C++23) Iterator-Paar-Konstruktoren für std::queue und std::stack; Überladungen (2) und (4)
__cpp_lib_containers_ranges 202202L (C++23) Bereichsbezogene Konstruktion und Einfügung; Überladungen (5) und (6)

[bearbeiten] Beispiel

#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>>
}