Namensräume
Varianten
Aktionen

std::unary_function

Von cppreference.com
< cpp‎ | utility‎ | functional
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
 
Funktionsobjekte
Funktionsaufruf
(C++17)(C++23)
Identitätsfunktions-Objekt
(C++20)
Transparente Operator-Wrapper
(C++14)
(C++14)
(C++14)
(C++14)  
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)

Alte Binder und Adaptoren
unary_function
(bis C++17*)
(bis C++17*)
(bis C++17*)
(bis C++17*)
(bis C++17*)(bis C++17*)(bis C++17*)(bis C++17*)
(bis C++20*)
(bis C++20*)
(bis C++17*)(bis C++17*)
(bis C++17*)(bis C++17*)

(bis C++17*)
(bis C++17*)(bis C++17*)(bis C++17*)(bis C++17*)
(bis C++20*)
(bis C++20*)
 
Definiert in der Header-Datei <functional>
template< typename ArgumentType, typename ResultType >
struct unary_function;
(in C++11 veraltet)
(removed in C++17)

std::unary_function ist eine Basisklasse zur Erstellung von Funktions-Objekten mit einem Argument.

std::unary_function definiert keine operator(); es wird erwartet, dass abgeleitete Klassen diese definieren. std::unary_function stellt nur zwei Typen - argument_type und result_type - bereit, die durch die Template-Parameter definiert werden.

Einige Standardbibliotheks-Funktions-Objekt-Adaptoren, wie z.B. std::not1, erfordern, dass die von ihnen adaptierten Funktions-Objekte bestimmte Typen definiert haben; std::not1 erfordert, dass das adaptierte Funktions-Objekt einen Typ namens argument_type hat. Das Ableiten von Funktions-Objekten, die ein Argument entgegennehmen, von std::unary_function ist eine einfache Möglichkeit, sie mit diesen Adaptoren kompatibel zu machen.

std::unary_function ist in C++11 veraltet.

[bearbeiten] Member types

Typ Definition
argument_type ArgumentType
result_type ResultType

[bearbeiten] 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 solution:
    // Cast to std::function<bool (int)> somehow - even with a lambda
    // std::cout << std::count_if(v.begin(), v.end(),
    //     std::not1(std::function<bool (int)>([](int i) { return i < 7; })));
}

Ausgabe

7

[bearbeiten] Siehe auch

(C++11)
kopierfähiger Wrapper für jedes kopierkonstruierbare aufrufbare Objekt
(Klassen-Template) [bearbeiten]
Move-only-Wrapper für jedes aufrufbare Objekt, das Qualifizierer in einer gegebenen Aufrufsignatur unterstützt
(Klassen-Template) [bearbeiten]
(in C++11 veraltet)(in C++17 entfernt)
erstellt einen adaptor-kompatiblen Funktionsobjekt-Wrapper aus einem Funktionszeiger
(Funktionsvorlage) [edit]
(in C++11 veraltet)(in C++17 entfernt)
Adaptor-kompatibler Wrapper für einen Zeiger auf eine unäre Funktion
(Klassenvorlage) [edit]
(in C++11 veraltet)(in C++17 entfernt)
Adaptor-kompatible Basisklasse für binäre Funktionen
(Klassenvorlage) [edit]