Namespaces
Variants

std::ranges::concat_view<Views...>:: end

From cppreference.net
Ranges library
Range adaptors
constexpr auto end ( )
requires ( ! ( /*simple-view*/ < Views > && ... ) ) ;
(1) (C++26 이후)
constexpr auto end ( ) const

requires ( ranges:: range < const Views > && ... ) &&

/*concatable*/ < const Views... > ;
(2) (C++26 이후)

iterator 또는 std::default_sentinel 을 반환하며, 이는 concat_view 의 끝 지난 반복자와 동일하게 비교됩니다.

1) 다음과 동등함:

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 ;

.
2) 다음과 동일함

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 ;

.

반환값

위에서 설명한 바와 같습니다.

예제

예비 버전은 Compiler Explorer 에서 확인할 수 있습니다.

#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);
}

참고 항목

시작을 가리키는 반복자를 반환합니다
(public member function)
범위의 끝을 나타내는 sentinel을 반환합니다
(customization point object)