Namensräume
Varianten
Aktionen

std::bind1st, std::bind2nd

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*)
(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*)
bind1stbind2nd
(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 F, class T >
std::binder1st<F> bind1st( const F& f, const T& x );
(1) (in C++11 veraltet)
(removed in C++17)
template< class F, class T >
std::binder2nd<F> bind2nd( const F& f, const T& x );
(2) (in C++11 veraltet)
(removed in C++17)

Bindet ein gegebenes Argument x an den ersten oder zweiten Parameter des gegebenen binären Funktions-Objekts f. Das heißt, x wird innerhalb des resultierenden Wrappers gespeichert, der, wenn er aufgerufen wird, x als ersten oder zweiten Parameter von f übergibt.

1) Bindet das erste Argument von f an x. Ruft effektiv std::binder1st<F>(f, typename F::first_argument_type(x)) auf.
2) Bindet das zweite Argument von f an x. Ruft effektiv std::binder2nd<F>(f, typename F::second_argument_type(x)) auf.

Inhalt

[edit] Parameter

f - Zeiger auf eine Funktion, an die ein Argument gebunden werden soll
x - Argument, das an f gebunden werden soll

[edit] Rückgabewert

Ein Funktions-Objekt, das f und x umschließt.

[edit] Exceptions

Kann implementierungsdefinierte Ausnahmen auslösen.

[edit] Beispiel

#include <algorithm>
#include <cmath>
#include <cstddef>
#include <functional>
#include <iomanip>
#include <iostream>
#include <vector>
 
int main()
{
    std::vector<double> a = {0, 30, 45, 60, 90, 180};
    std::vector<double> r(a.size());
    const double pi = std::acos(-1); // since C++20 use std::numbers::pi
 
    std::transform(a.begin(), a.end(), r.begin(),
        std::bind1st(std::multiplies<double>(), pi / 180.0));
//  an equivalent lambda is: [pi](double a) { return a * pi / 180.0; });
 
    for (std::size_t n = 0; n < a.size(); ++n)
        std::cout << std::setw(3) << a[n] << "° = " << std::fixed << r[n]
                  << " rad\n" << std::defaultfloat;
}

Ausgabe

  0° = 0.000000 rad
 30° = 0.523599 rad
 45° = 0.785398 rad
 60° = 1.047198 rad
 90° = 1.570796 rad
180° = 3.141593 rad

[edit] Siehe auch

(in C++11 veraltet)(in C++17 entfernt)
Funktionsobjekt, das eine binäre Funktion und eines ihrer Argumente speichert
(Klassenvorlage) [edit]
(C++20)(C++23)
bindet eine variable Anzahl von Argumenten, in Reihenfolge, an ein Funktions-Objekt
(Funktions-Template) [bearbeiten]