std::ranges::elements_of
From cppreference.com
Defined in header <ranges> | ||
template<ranges::range R, class Allocator =std::allocator<std::byte>> struct elements_of; | (since C++23) | |
Encapsulates a range
. Specializations of elements_of
act as a tag in overload sets to disambiguate when a range should be treated as a sequence rather than a single value.
Contents |
[edit]Template parameters
R | - | a type that satisfies range |
Allocator | - | an allocator type that meets the requirements of Allocator |
[edit]Data members
Member name | Definition |
range | a range of type R (public member object) |
allocator | an allocator of type Allocator . It has default member initializer that value initializes itself (public member object) |
All these members are declared with [[no_unique_address]]
attribute.
[edit]Deduction guide
template<class R, class Allocator =std::allocator<std::byte>> elements_of( R&&, Allocator = Allocator())-> elements_of<R&&, Allocator>; | (since C++23) | |
[edit]Example
Run this code
#include <any>#include <generator>#include <iostream>#include <ranges>#include <string_view> template<bool Elementwise>std::generator<std::any> gen(std::ranges::input_rangeauto&& r){ifconstexpr(Elementwise) co_yield std::ranges::elements_of(r);// yield each element of relse co_yield r;// yield r as a single value} int main(){auto test =std::string_view{"test"}; for(std::any a : gen<true>(test))std::cout<<'['<<std::any_cast<char>(a)<<"] ";std::cout<<'\n'; for(std::any a : gen<false>(test))std::cout<<'['<<std::any_cast<std::string_view>(a)<<"] ";std::cout<<'\n';}
Output:
[t] [e] [s] [t] [test]
[edit]References
- C++23 standard (ISO/IEC 14882:2024):
- 26.5.6 Class template elements_of [range.elementsof]