Namensräume
Varianten
Aktionen

std::projected

Von cppreference.com
< cpp‎ | iterator
 
 
Iterator-Bibliothek
Iterator-Konzepte
Iterator-Primitive
Algorithmus-Konzepte und Hilfsprogramme
Indirekte aufrufbare Konzepte
Gemeinsame Algorithmus-Anforderungen
(C++20)
(C++20)
(C++20)
Dienstprogramme
projected
(C++20)
Iterator-Adapter
Bereichszugriff
(C++11)(C++14)
(C++14)(C++14)  
(C++11)(C++14)
(C++14)(C++14)  
(C++17)(C++20)
(C++17)
(C++17)
 
Definiert in Header <iterator>
(1)
template< std::indirectly_readable I,

          std::indirectly_regular_unary_invocable<I> Proj >
struct projected
{
    using value_type = std::remove_cvref_t<std::indirect_result_t<Proj&, I>>;
    std::indirect_result_t<Proj&, I> operator*() const; // nicht definiert

};
(seit C++20)
(bis C++26)
template< std::indirectly_readable I,

          std::indirectly_regular_unary_invocable<I> Proj >

using projected = /*projected-impl*/<I, Proj>::/*__type*/; // siehe (3)
(seit C++26)
template< std::weakly_incrementable I, class Proj >

struct incrementable_traits<std::projected<I, Proj>>
{
    using difference_type = std::iter_difference_t<I>;

};
(2) (seit C++20)
(bis C++26)
template< class I, class Proj >

struct /*projected-impl*/
{
    struct /*__type*/
    {
        using value_type = std::remove_cvref_t<std::indirect_result_t<Proj&, I>>;
        using difference_type = std::iter_difference_t<I>; // bedingt vorhanden

        std::indirect_result_t<Proj&, I> operator*() const; // nicht definiert
    };

};
(3) (seit C++26)
(nur Exposition*)
1) Klasse(bis C++26)Alias(seit C++26) template 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.
2) Diese Spezialisierung von std::incrementable_traits macht std::projected<I, Proj> zu einem weakly_incrementable-Typ, wenn I ebenfalls ein weakly_incrementable-Typ ist.
3) Eine indirekte Schicht, die verwendet wird, um unerwartete argumentabhängige Suche zu vermeiden. Der Mitgliedstyp 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

berechnet den Werttyp eines indirectly_readable Typs mittels Projektion
(Alias-Vorlage)[bearbeiten]