Namespaces
Variants

std:: unary_function

From cppreference.net
Utilities library
Function objects
Function invocation
(C++17) (C++23)
Identity function object
(C++20)
Old binders and adaptors
unary_function
( until C++17* )
( until C++17* )
( until C++17* )
( until C++17* )
( until C++17* ) ( until C++17* ) ( until C++17* ) ( until C++17* )
( until C++20* )
( until C++20* )
( until C++17* ) ( until C++17* )
( until C++17* ) ( until C++17* )

( until C++17* )
( until C++17* ) ( until C++17* ) ( until C++17* ) ( until C++17* )
( until C++20* )
( until C++20* )
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)
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)