Namespaces
Variants

std:: unreachable_sentinel_t, std:: unreachable_sentinel

From cppreference.net
Iterator library
Iterator concepts
Iterator primitives
Algorithm concepts and utilities
Indirect callable concepts
Common algorithm requirements
(C++20)
(C++20)
(C++20)
Utilities
(C++20)
Iterator adaptors
unreachable_sentinel_t unreachable_sentinel
(C++20) (C++20)
Range access
(C++11) (C++14)
(C++14) (C++14)
(C++11) (C++14)
(C++14) (C++14)
(C++17) (C++20)
(C++17)
(C++17)
Определено в заголовочном файле <iterator>
struct unreachable_sentinel_t ;
(1) (начиная с C++20)
inline constexpr unreachable_sentinel_t unreachable_sentinel { } ;
(2) (начиная с C++20)
1) unreachable_sentinel_t — это пустой классовый тип, который может использоваться для обозначения «верхней границы» неограниченного интервала.
2) unreachable_sentinel является константой типа unreachable_sentinel_t .

Содержание

Функции, не являющиеся членами класса

operator==
(C++20)
сравнивает unreachable_sentinel_t со значением любого weakly_incrementable типа
(шаблон функции)

operator== (std::unreachable_sentinel_t)

template < std:: weakly_incrementable I >

friend constexpr bool operator == ( unreachable_sentinel_t, const I & ) noexcept

{ return false ; }
(since C++20)

unreachable_sentinel_t может сравниваться с любым типом weakly_incrementable и результат всегда равен false .

Этот шаблон функции не виден при обычном неквалифицированном или квалифицированном поиске и может быть найден только с помощью поиска, зависимого от аргументов , когда std::unreachable_sentinel_t является ассоциированным классом аргументов.

Пример

#include <concepts>
#include <cstddef>
#include <iterator>
#include <ranges>
#include <utility>
namespace ranges = std::ranges;
// никогда не проверяет "iter != r.end()"
template<ranges::random_access_range R>
constexpr std::size_t trivial_strlen(R&& r)
{
    auto iter = r.begin();
    while (*iter != ranges::range_value_t<R>{})
        ++iter;
    return iter - r.begin();
}
template<ranges::random_access_range R>
constexpr std::size_t my_strlen(R&& r)
{
    if constexpr (std::same_as<ranges::sentinel_t<R>,
                               std::unreachable_sentinel_t>)
        return trivial_strlen(std::forward<R>(r));
    else
        return ranges::find(std::forward<R>(r), ranges::range_value_t<R>{}) -
               ranges::begin(r);
}
int main()
{
    constexpr static char str[] = "The quick brown fox jumps over a lazy dog.";
    static_assert(my_strlen(str) == 42);
    // находит длину строки быстрее, но UB если "str" не нуль-терминирован
    constexpr auto unsafe_str = ranges::subrange{str, std::unreachable_sentinel};
    static_assert(my_strlen(unsafe_str) == 42);
}

Смотрите также

view состоящий из последовательности, генерируемой повторным инкрементом начального значения
(шаблон класса) (объект точки кастомизации)