table of contents
        
      
      
    | std::ranges::get(std::ranges::subrange)(3) | C++ Standard Libary | std::ranges::get(std::ranges::subrange)(3) | 
NAME¶
std::ranges::get(std::ranges::subrange) - std::ranges::get(std::ranges::subrange)
Synopsis¶
 Defined in header <ranges>
  
   template< std::size_t N, class I, class S, ranges::subrange_kind K
  
   >
  
   (1) (since C++20)
  
   requires ((N == 0 && std::copyable<I>) || N == 1)
  
   constexpr auto get( const ranges::subrange<I, S, K>& r );
  
   template< std::size_t N, class I, class S, ranges::subrange_kind K
  
   >
  
   (2) (since C++20)
  
   requires (N < 2)
  
   constexpr auto get( ranges::subrange<I, S, K>&& r );
  
   namespace std { using ranges::get; } (3) (since C++20)
  
   1) Obtains the iterator or sentinel from a subrange lvalue (or a const
    rvalue) when
  
   N == 0 or N == 1, respectively. It is mainly provided for structured binding
  
   support.
  
   2) Same as (1), except that it takes a non-const subrange rvalue.
  
   3) (1,2) are imported into namespace std, which simplifies their usage and
    makes
  
   every subrange with a copyable iterator a pair-like type.
Parameters¶
r - a subrange
Return value¶
 1) An iterator or sentinel copy constructed from the stored one
    when N == 0 or N ==
  
   1, respectively.
  
   2) Same as (1), except that the iterator is move constructed if N == 0
    and I does
  
   not satisfy copyable.
Possible implementation¶
 template<std::size_t N, class I, class S,
    std::ranges::subrange_kind K>
  
   requires ((N == 0 && std::copyable<I>) || N == 1)
  
   constexpr auto get(const std::ranges::subrange<I, S, K>& r)
  
   {
  
   if constexpr (N == 0)
  
   return r.begin();
  
   else
  
   return r.end();
  
   }
  
   template<std::size_t N, class I, class S, std::ranges::subrange_kind K>
  
   requires (N < 2)
  
   constexpr auto get(std::ranges::subrange<I, S, K>&& r)
  
   {
  
   if constexpr (N == 0)
  
   return r.begin(); // may perform move construction
  
   else
  
   return r.end();
  
   }
Example¶
// Run this code
  
   #include <array>
  
   #include <iostream>
  
   #include <iterator>
  
   #include <ranges>
  
   int main()
  
   {
  
   std::array a{1, -2, 3, -4};
  
   std::ranges::subrange sub_a{std::next(a.begin()), std::prev(a.end())};
  
   std::cout << *std::ranges::get<0>(sub_a) << ' ' // ==
    *(begin(a) + 1)
  
   << *get<1>(sub_a) << '\n'; // == *(end(a) - 1)
  
   *get<0>(sub_a) = 42; // OK
  
   // *get<2>(sub_a) = 13; // hard error: index can only be 0 or 1
  
   }
Output:¶
-2 -4
  
   Defect reports
  
   The following behavior-changing defect reports were applied retroactively to
  
   previously published C++ standards.
  
   DR Applied to Behavior as published Correct behavior
  
   the overload for const lvalue was it is removed from the
  
   LWG 3589 C++20 ill-formed if N == 0 overload set
  
   and I does not model copyable
See also¶
 Structured binding (C++17) binds the specified names to
    sub-objects or tuple
  
   elements of the initializer
  
   get(std::tuple) tuple accesses specified element
  
   (C++11) (function template)
  
   get(std::pair) accesses an element of a pair
  
   (C++11) (function template)
  
   get(std::array) accesses an element of an array
  
   (C++11) (function template)
| 2024.06.10 | http://cppreference.com |