std::ranges::concat_view<Views...>::begin
From cppreference.com
 
 
 < cpp | ranges | concat view 
 
 
 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::concat_view 
 
concat_view::begin
constexpr /*iterator*/<false> begin()
requires (!(/*simple-view*/<Views> && ...));
 (1) 
 (since C++26) 
requires (!(/*simple-view*/<Views> && ...));
constexpr /*iterator*/<true> begin() const
 (2) 
 (since C++26) 
    requires (ranges::range <const Views> && ...) &&
Returns an iterator to the beginning of the concat_view.
1) Equivalent to 
it.template
return it;.
iterator <false> it(this, std::in_place_index <0>,                   ranges::begin (std::get<0>(views_  )));it.template
 satisfy  <0>();return it;.
2) Equivalent to 
it.template
return it;.
iterator <true> it(this, std::in_place_index <0>,                  ranges::begin (std::get<0>(views_  )));it.template
 satisfy  <0>();return it;.
[edit] Return value
As specified above.
[edit] Example
The preliminary version can be checked out on Compiler Explorer.
Run this code
#include <ranges> #include <string_view> using namespace std::literals; int main() { static constexpr auto c = {"🐱", "🐶"}; static constexpr auto a = {"🤡"sv}; static constexpr auto t = {"💚"sv}; static constexpr auto cat{std::views::concat (c, a, t)}; static_assert(*cat.begin() == "\U0001F431" and cat.begin()[1] == "🐶" and *(cat.begin() + 2) == "\N{CLOWN FACE}"); }