std::indirectly_unary_invocable, std::indirectly_regular_unary_invocable
| Definiert in Header <iterator> |
||
std::indirectly_unary_invocable |
||
| template< class F, class I > concept indirectly_unary_invocable = |
(seit C++20) | |
std::indirectly_regular_unary_invocable |
||
| template< class F, class I > concept indirectly_regular_unary_invocable = |
(seit C++20) | |
Die Konzepte indirectly_unary_invocable und indirectly_regular_unary_invocable spezifizieren Anforderungen für Algorithmen, die (reguläre) unäre Invocables als ihre Argumente aufrufen. Der Hauptunterschied zwischen diesen Konzepten und std::invocable besteht darin, dass sie auf den Typ angewendet werden, auf den I verweist, anstatt auf I selbst.
[bearbeiten] Hinweise
Die Unterscheidung zwischen indirectly_unary_invocable und indirectly_regular_unary_invocable ist rein semantisch.
[bearbeiten] Beispiel
#include <algorithm> #include <iterator> #include <print> #include <ranges> struct IntWrapper { int i; explicit IntWrapper(int i) : i(i) {} IntWrapper(IntWrapper&&) = default; IntWrapper& operator=(IntWrapper&&) = default; }; int main() { auto ints = std::views::iota(1, 10); auto print = [] (IntWrapper w) { std::print("{} ", w.i); }; auto wrap = [] (int i) { return IntWrapper{i}; }; using Proj = std::projected<decltype(ints.begin()), decltype(wrap)>; // error (evaluated to false) until P2609R3: // this was because 'std::iter_value_t<Proj> &' is the same as 'IntWrapper&' // which is not convertible to 'IntWrapper' (implicitly deleted copy ctor) static_assert(std::indirectly_unary_invocable<decltype(print), Proj>); // if the compile-time check above evaluates to true, then this is well-formed: std::ranges::for_each(ints, print, wrap); }
Ausgabe
1 2 3 4 5 6 7 8 9
[bearbeiten] Fehlerberichte
Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
| P2609R3 | C++20 | einige Anforderungen wurden in Bezug auf std::iter_value_t<I>& definiert was Projektionen falsch behandelte, was zu Inkompatibilität mit invocable F& führte |
definiert in Bezug auf /*indirect-value-t*/<I> um solche Projektionen korrekt zu behandeln |
| P2997R1 | C++20 | entsprechende Konzepte erforderten, dass F& invocable undregular_invocable erfüllte, jeweils mit std::iter_common_reference_t<I> |
erfordert nicht |