std::ranges::concat_view<Views...>::begin
Von cppreference.com
< cpp | ranges | concat view
| constexpr /*iterator*/<false> begin() requires (!(/*simple-view*/<Views> && ...)); |
(1) | (seit C++26) |
| constexpr /*iterator*/<true> begin() const requires (ranges::range<const Views> && ...) && |
(2) | (seit C++26) |
Gibt einen Iterator zum Anfang der concat_view zurück.
1) Entspricht
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) Entspricht
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;.
[Bearbeiten] Rückgabewert
Wie oben angegeben.
[Bearbeiten] Beispiel
Die vorläufige Version kann auf Compiler Explorer überprüft werden.
Führen Sie diesen Code aus
#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}"); }
[Bearbeiten] Siehe auch
| gibt einen Iterator oder Sentinel zum Ende zurück (öffentliche Member-Funktion) | |
| (C++20) |
gibt einen Iterator zum Anfang eines Ranges zurück (Customization Point Objekt) |