std::projected
|   Defined in header  <iterator>
  | 
||
| (1) | ||
template< std::indirectly_readable I,           std::indirectly_regular_unary_invocable<I> Proj >  | 
(since C++20)  (until C++26)  | 
|
|   template< std::indirectly_readable I,           std::indirectly_regular_unary_invocable<I> Proj >  | 
(since C++26) | |
|   template< std::weakly_incrementable I, class Proj > struct incrementable_traits<std::projected<I, Proj>>  | 
(2) |  (since C++20)  (until C++26)  | 
|   template< class I, class Proj > struct /*projected-impl*/  | 
(3) |  (since C++26)  (exposition only*)  | 
projected combines an indirectly_readable type I and a callable object type Proj into a new indirectly_readable type whose reference type is the result of applying Proj to the std::iter_reference_t<I>.weakly_incrementable type when I is also a weakly_incrementable type.difference_type exists only if I models weakly_incrementable.projected is used only to constrain algorithms that accept callable objects and projections, and hence its operator*() is not defined.
Template parameters
| I | - | an indirectly readable type | 
| Proj | - |  projection applied to a dereferenced I
 | 
Notes
The indirect layer prevents I and Proj to be associated classes of projected. When an associated class of I or Proj is an incomplete class type, the indirect layer avoids the unnecessary attempt to inspect the definition of that type that results in hard error.
Example
#include <algorithm> #include <cassert> #include <functional> #include <iterator> template<class T> struct Holder { T t; }; struct Incomplete; using P = Holder<Incomplete>*; static_assert(std::equality_comparable<P>); // OK static_assert(std::indirectly_comparable<P*, P*, std::equal_to<>>); // Error before C++26 static_assert(std::sortable<P*>); // Error before C++26 int main() { P a[10] = {}; // ten null pointers assert(std::count(a, a + 10, nullptr) == 10); // OK assert(std::ranges::count(a, a + 10, nullptr) == 10); // Error before C++26 }
See also
|   (C++26)  | 
 computes the value type of an indirectly_readable type by projection(alias template)  |