Namensräume
Varianten
Aktionen

std::binary_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
(bis C++17*)
binary_function
(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<

    class Arg1,
    class Arg2,
    class Result

> struct binary_function;
(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) [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 binäre Funktion
(Klassenvorlage) [edit]
(in C++11 veraltet)(in C++17 entfernt)
Adaptor-kompatible Basisklasse für unäre Funktionen
(Klassenvorlage) [edit]