std::binary_function
| Definiert in der Header-Datei <functional> |
||
| template< class Arg1, |
(in C++11 veraltet) (removed in C++17) |
|
std::binary_function ist eine Basisklasse zur Erstellung von Funktions-Objekten mit zwei Argumenten.
std::binary_function definiert keinen operator(); es wird erwartet, dass abgeleitete Klassen diesen definieren. std::binary_function stellt nur drei Typen - first_argument_type, second_argument_type und result_type - zur Verfügung, die durch die Template-Parameter definiert sind.
Einige Standard-Bibliotheks-Funktions-Objekt-Adaptoren, wie z.B. std::not2, erfordern, dass die Funktions-Objekte, die sie adaptieren, bestimmte Typen definiert haben; std::not2 erfordert, dass das adaptierte Funktions-Objekt zwei Typen namens first_argument_type und second_argument_type hat. Das Ableiten von Funktions-Objekten, die zwei Argumente entgegennehmen, von std::binary_function ist eine einfache Möglichkeit, sie mit diesen Adaptoren kompatibel zu machen.
std::binary_function ist in C++11 veraltet und in C++17 entfernt worden.
[bearbeiten] Member types
| Typ | Definition |
first_argument_type
|
Arg1
|
second_argument_type
|
Arg2
|
result_type
|
Ergebnis
|
[bearbeiten] Beispiel
#include <algorithm> #include <functional> #include <iostream> #include <vector> struct same : std::binary_function<int, int, bool> { bool operator()(int a, int b) const { return a == b; } }; int main() { std::vector<char> v1{'A', 'B', 'C', 'D', 'E'}; std::vector<char> v2{'E', 'D', 'C', 'B', 'A'}; std::vector<bool> v3(v1.size()); std::transform(v1.begin(), v1.end(), v2.begin(), v3.begin(), std::not2(same())); std::cout << std::boolalpha; for (std::size_t i = 0; i < v1.size(); ++i) std::cout << v1[i] << " != " << v2[i] << " : " << v3[i] << '\n'; }
Ausgabe
A != E : true B != D : true C != C : false D != B : true E != A : true
[bearbeiten] Siehe auch
| (C++11) |
kopierfähiger Wrapper für jedes kopierkonstruierbare aufrufbare Objekt (Klassen-Template) |
| (C++23) |
Move-only-Wrapper für jedes aufrufbare Objekt, das Qualifizierer in einer gegebenen Aufrufsignatur unterstützt (Klassen-Template) |
| (in C++11 veraltet)(in C++17 entfernt) |
erstellt einen adaptor-kompatiblen Funktionsobjekt-Wrapper aus einem Funktionszeiger (Funktionsvorlage) |
| (in C++11 veraltet)(in C++17 entfernt) |
Adaptor-kompatibler Wrapper für einen Zeiger auf eine binäre Funktion (Klassenvorlage) |
| (in C++11 veraltet)(in C++17 entfernt) |
Adaptor-kompatible Basisklasse für unäre Funktionen (Klassenvorlage) |