std::ranges::elements_view<V,F>::iterator<Const>::operator*
From cppreference.com
 
 
 < cpp | ranges | elements view | iterator 
 
 
 C++ 
 Feature test macros (C++20)
 Concepts library (C++20)
 Metaprogramming library (C++11)
 Ranges library (C++20)
 Filesystem library (C++17)
 Concurrency support library (C++11)
 Execution control library (C++26)
Ranges library 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
(C++23)(C++23)
  (C++26)(C++26)
(C++23)(C++23)
  (C++26)(C++26)
(C++26)(C++26)
  (C++23)(C++23)
(C++23)(C++23)
(C++23)(C++23)
(C++23)(C++23)
  (C++23)(C++23)
(C++23)
(C++23)(C++23)
(C++23)
(C++23)(C++23)
(C++23)(C++23)
(C++23)(C++23)
(C++23)(C++23)
(C++23)(C++23)
std::ranges::elements_view 
 
 
(C++26)
elements_view::iterator::operator*
constexpr decltype(auto) operator*() const;
 
 (since C++20) 
Returns the element into V the underlying iterator points to.
Effectively returns /*get-element*/(this->base()), where for an expression e, /*get-element*/(e) is
- std::get<N>(*e), if ranges::range_reference_t <Base> is a reference type. Otherwise,
- static_cast<E>(std::get<N>(*e)), where E is std::remove_cv_t <std::tuple_element_t <N, ranges::range_reference_t <Base>>>.
Contents
[edit] Parameters
(none)
[edit] Return value
The current element.
[edit] Notes
operator-> is not provided.
[edit] Example
Run this code
#include <iostream> #include <ranges> #include <string_view> #include <tuple> int main() { using T = std::tuple <int, char, std::string_view >; const auto il = { T{1, 'A', "α"}, T{2, 'B', "β"}, T{3, 'C', "γ"}, }; const auto view {il | std::views::elements <2>}; const auto iter {view.begin() + 1}; std::cout << *iter << '\n'; }
Output:
β