|
Range primitives | |||||||
|
Range concepts | ||||||||||||||||||||||||||||||||||
|
|
Range factories | |||||||||
|
Range adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
Helper items | |||||||||||||||||
|
Defined in header <ranges> | ||
(1) | ||
template<class T> concept sized_range=ranges::range<T>&& | (since C++20) (until C++26) | |
template<class T> concept sized_range= ranges::approximately_sized_range<T>&& | (since C++26) | |
template<class> constexprbool disable_sized_range=false; | (2) | (since C++20) |
sized_range
concept specifies the requirements of arange
(until C++26)approximately_sized_range
(since C++26) type that knows its size in constant time with thesize
function.disable_sized_range
exists to allow use of range types that provide asize
function (either as a member or as a non-member) but do not in fact modelsized_range
. Users may specializedisable_sized_range
for cv-unqualified program-defined types. Such specializations shall be usable inconstant expressions and have typeconstbool.Contents |
T
modelssized_range
only ifforward_iterator
,ranges::size(t) is well-defined regardless of the evaluation ofranges::begin(t) (in other words, a single-pass sized range may support a call to size only before the first call to begin, but a forward range must support size at all times).disable_sized_range
cannot be used to opt-out a range whose iterator and sentinel satisfysized_sentinel_for
;std::disable_sized_sentinel_for must be used instead.
disable_sized_range
cannot be specialized for array types or reference types.
Feature-test macro | Value | Std | Feature |
---|---|---|---|
__cpp_lib_ranges_reserve_hint | 202502L | (C++26) | ranges::approximately_sized_range andranges::reserve_hint |
#include <forward_list>#include <list>#include <ranges> static_assert( std::ranges::sized_range<std::list<int>> and not std::ranges::sized_range<std::forward_list<int>>); int main(){}
(C++20) | specifies a range whose iterator type satisfiesrandom_access_iterator (concept)[edit] |
(C++20) | specifies a range whose iterator type satisfiescontiguous_iterator (concept)[edit] |