std::ranges::concat_view<Views...>:end
| constexpr auto end() requires (!(/*simple-view*/<Views> && ...)); |
(1) | (seit C++26) |
| constexpr auto end() const erfordert (ranges::range<const Views> && ...) && |
(2) | (seit C++26) |
Gibt einen Iterator oder std::default_sentinel zurück, der gleich dem Past-the-End-Iterator des concat_view ist.
constexpr auto N = sizeof...(Views);
if constexpr (ranges::common_range<Views...[N - 1]>) return iterator <false>(this, std::in_place_index<N - 1>, ranges::end(std::get<N - 1>(views_ )));
else return std::default_sentinel;
constexpr auto N = sizeof...(Views);
if constexpr (ranges::common_range<const Views...[N - 1]>) return iterator <true>(this, std::in_place_index<N - 1>, ranges::end(std::get<N - 1>(views_ )));
else return std::default_sentinel;
[bearbeiten] Rückgabewert
Wie oben beschrieben.
[bearbeiten] Beispiel
Die vorläufige Version kann auf Compiler Explorer eingesehen werden.
#include <concepts> #include <iterator> #include <ranges> int main() { static constexpr int p[]{37, 42, 69}; static constexpr auto q = {19937, 1729}; constexpr auto cat = std::ranges::views::concat(p, q); static_assert(not std::same_as<std::default_sentinel_t, decltype(cat.end())>); static_assert(cat.end()[-1] == 1729); }
[bearbeiten] Siehe auch
| gibt einen Iterator zum Anfang zurück (öffentliche Member-Funktion) | |
| (C++20) |
gibt ein Sentinel zurück, das das Ende eines Ranges anzeigt (Customization Point Objekt) |