std:: unary_function
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Old binders and adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
Definiert im Header
<functional>
|
||
|
template
<
typename
ArgumentType,
typename
ResultType
>
struct unary_function ; |
(veraltet in C++11)
(entfernt in C++17) |
|
std::unary_function
ist eine Basisklasse zur Erstellung von Funktionsobjekten mit einem Argument.
std::unary_function
definiert kein
operator
(
)
; es wird erwartet, dass abgeleitete Klassen diesen definieren.
std::unary_function
stellt nur zwei Typen bereit -
argument_type
und
result_type
- die durch die Template-Parameter definiert werden.
Einige Standardbibliothek-Funktionsobjektadapter, wie
std::not1
, erfordern, dass die Funktionsobjekte, die sie anpassen, bestimmte Typen definieren;
std::not1
erfordert, dass das angepasste Funktionsobjekt einen Typ namens
argument_type
besitzt. Das Ableiten von Funktionsobjekten, die ein Argument nehmen, von
std::unary_function
ist eine einfache Methode, um sie mit diesen Adaptern kompatibel zu machen.
std::unary_function
ist in C++11 veraltet.
Mitgliedertypen
| Typ | Definition |
argument_type
|
ArgumentType
|
result_type
|
ResultType
|
Beispiel
#include <algorithm> #include <functional> #include <iostream> #include <vector> struct less_than_7 : std::unary_function<int, bool> { bool operator()(int i) const { return i < 7; } }; int main() { std::vector<int> v(10, 7); v[0] = v[1] = v[2] = 6; std::cout << std::count_if(v.begin(), v.end(), std::not1(less_than_7())); // C++11-Lösung: // Irgendwie nach std::function<bool (int)> casten - selbst mit einem Lambda // std::cout << std::count_if(v.begin(), v.end(), // std::not1(std::function<bool (int)>([](int i) { return i < 7; }))); }
Ausgabe:
7
Siehe auch
|
(C++11)
|
kopierbarer Wrapper für jedes kopierkonstruierbare aufrufbare Objekt
(Klassentemplate) |
|
(C++23)
|
Nur-verschiebbarer Wrapper für jedes aufrufbare Objekt, das Qualifizierer in einer gegebenen Aufrufsignatur unterstützt
(Klassentemplate) |
|
(deprecated in C++11)
(removed in C++17)
|
erstellt einen adapterkompatiblen Funktionsobjekt-Wrapper aus einem Funktionszeiger
(Funktionstemplate) |
|
(deprecated in C++11)
(removed in C++17)
|
adapterkompatibler Wrapper für einen Zeiger auf eine unäre Funktion
(Klassentemplate) |
|
(deprecated in C++11)
(removed in C++17)
|
adapterkompatible Basisklasse für binäre Funktionen
(Klassentemplate) |