std::ranges::iterator_t, std::ranges::const_iterator_t, std::ranges::sentinel_t, std::ranges::const_sentinel_t
| Defined in header <ranges>
|
||
| template< class T > using iterator_t = decltype(ranges::begin(std::declval<T&>())); |
(1) | (since C++20) |
| template< ranges::range R > using const_iterator_t = decltype(ranges::cbegin(std::declval<R&>())); |
(2) | (since C++23) |
| template< ranges::range R > using sentinel_t = decltype(ranges::end(std::declval<R&>())); |
(3) | (since C++20) |
| template< ranges::range R > using const_sentinel_t = decltype(ranges::cend(std::declval<R&>())); |
(4) | (since C++23) |
T.R.R.Contents |
[edit] Template parameters
| T | - | a type that can be used in std::ranges::begin |
| R | - | a range type or a sized_range type
|
[edit] Notes
iterator_t can be applied to non-range types, e.g. arrays with unknown bound.
[edit] Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 3946 | C++23 | const_iterator_t and const_sentinel_t were inconsistentwith the result of ranges::cbegin and ranges::cend respectively
|
tweaked |
[edit] See also
| (C++20)(C++20)(C++23)(C++20)(C++20)(C++20) |
computes the associated types of an iterator (alias template) |
| (C++20)(C++20)(C++20) |
obtains size, difference, and value types of a range (alias template) |
| obtains reference types of a range (alias template) |

Formed in 2009, the Archive Team (not to be confused with the archive.org Archive-It Team) is a rogue archivist collective dedicated to saving copies of rapidly dying or deleted websites for the sake of history and digital heritage. The group is 100% composed of volunteers and interested parties, and has expanded into a large amount of related projects for saving online and digital history.
