std:: projected
|
Definiert im 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) |
|
Hilfsvorlagen
|
||
|
template
<
class
I,
class
Proj
>
struct
/*projected-impl*/
|
(3) |
(seit C++26)
( nur zur Darstellung* ) |
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 den
std::
iter_reference_t
<
I
>
ist.
weakly_incrementable
-Typ, wenn
I
ebenfalls ein
weakly_incrementable
-Typ ist.
difference_type
nur, wenn
I
das Konzept
weakly_incrementable
modelliert.
projected
wird nur verwendet, um Algorithmen einzuschränken, die aufrufbare Objekte und Projektionen akzeptieren, und daher ist sein
operator
*
(
)
nicht definiert.
Inhaltsverzeichnis |
Template-Parameter
| I | - | ein indirekt lesbarer Typ |
| Proj | - |
Projektion angewendet auf ein dereferenziertes
I
|
Hinweise
Die indirekte Ebene 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 Ebene den unnötigen Versuch, die Definition dieses Typs zu inspizieren, was zu einem schwerwiegenden Fehler führen würde.
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<>>); // Fehler vor C++26 static_assert(std::sortable<P*>); // Fehler vor C++26 int main() { P a[10] = {}; // zehn Nullzeiger assert(std::count(a, a + 10, nullptr) == 10); // OK assert(std::ranges::count(a, a + 10, nullptr) == 10); // Fehler vor C++26 }
Siehe auch
|
(C++26)
|
berechnet den Werttyp eines
indirectly_readable
Typs durch Projektion
(Alias-Template) |