std::projected
| Definiert in Header <iterator> |
||
| (1) | ||
template< std::indirectly_readable I, std::indirectly_regular_unary_invocable<I> Proj > |
(seit C++20) (bis C++26) |
|
| template< std::indirectly_readable I, std::indirectly_regular_unary_invocable<I> Proj > |
(seit C++26) | |
| template< std::weakly_incrementable I, class Proj > struct incrementable_traits<std::projected<I, Proj>> |
(2) | (seit C++20) (bis C++26) |
| template< class I, class Proj > struct /*projected-impl*/ |
(3) | (seit C++26) (nur Exposition*) |
projected kombiniert einen indirectly_readable-Typ I und einen aufrufbaren Objekttyp Proj zu einem neuen indirectly_readable-Typ, dessen Referenztyp das Ergebnis der Anwendung von Proj auf die std::iter_reference_t<I> ist.weakly_incrementable-Typ, wenn I ebenfalls ein weakly_incrementable-Typ ist.difference_type existiert nur, wenn I weakly_incrementable modelliert.projected wird nur verwendet, um Algorithmen zu beschränken, die aufrufbare Objekte und Projektionen akzeptieren, und daher ist sein operator*() nicht definiert.
Inhalt |
[bearbeiten] Template-Parameter
| I | - | ein indirekt lesbarer Typ |
| Proj | - | Projektion angewendet auf ein dereferenziertes I |
[bearbeiten] Hinweise
Die indirekte Schicht verhindert, dass I und Proj assoziierte Klassen von projected sind. Wenn eine assoziierte Klasse von I oder Proj ein unvollständiger Klassentyp ist, vermeidet die indirekte Schicht den unnötigen Versuch, die Definition dieses Typs zu untersuchen, was zu einem harten Fehler führt.
[bearbeiten] Beispiel
#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 }
[bearbeiten] Siehe auch
| (C++26) |
berechnet den Werttyp eines indirectly_readable Typs mittels Projektion(Alias-Vorlage) |