std:: unreachable_sentinel_t, std:: unreachable_sentinel
| Iterator concepts | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Iterator primitives | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Algorithm concepts and utilities | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Indirect callable concepts | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Common algorithm requirements | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Utilities | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Iterator adaptors | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
Определено в заголовочном файле
<iterator>
|
||
|
struct
unreachable_sentinel_t
;
|
(1) | (начиная с C++20) |
|
inline
constexpr
unreachable_sentinel_t unreachable_sentinel
{
}
;
|
(2) | (начиная с C++20) |
unreachable_sentinel_t
— это пустой классовый тип, который может использоваться для обозначения «верхней границы» неограниченного интервала.
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
|
(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); }
Смотрите также
|
(C++20)
|
view
состоящий из последовательности, генерируемой повторным инкрементом начального значения
(шаблон класса) (объект точки кастомизации) |