Поделиться через


Класс binder1st

Шаблон класса, предоставляющий конструктор, который преобразует двоичный объект функции в унарный объект функции путем привязки первого аргумента двоичной функции к указанному значению. Не рекомендуется использовать C++11 в пользу привязки и удален в C++17.

Синтаксис

template <class Operation>
class binder1st
    : public unaryFunction <typename Operation::second_argument_type,
                             typename Operation::result_type>
{
public:
    typedef typename Operation::argument_type argument_type;
    typedef typename Operation::result_type result_type;
    binder1st(
        const Operation& binary_fn,
        const typename Operation::first_argument_type& left);

    result_type operator()(const argument_type& right) const;
    result_type operator()(const argument_type& right) const;

protected:
    Operation op;
    typename Operation::first_argument_type value;
};

Параметры

binary_fn
Объект бинарной функции, который необходимо преобразовать в объект унарной функции.

left
Значение, к которому необходимо привязать первый аргумент объекта бинарной функции.

right
Значение аргумента, которое адаптированный объект бинарной функции сравнивает с фиксированным значением второго аргумента.

Возвращаемое значение

Унарный объект функции, который приводит к привязке первого аргумента двоичного объекта функции к значению слева.

Замечания

Шаблон класса хранит копию объекта двоичной функции binary_fn в op, а копия слева .value Она определяет свою функцию-член operator() как возвращаемую op(value, right).

Если binary_fn является объектом типа Operation и c является константой, то bind1st(binary_fn, c) это более удобный эквивалент binder1st<Operation>(binary_fn, c). Дополнительные сведения см. в разделе bind1st.

Пример

// functional_binder1st.cpp
// compile with: /EHsc
#include <vector>
#include <functional>
#include <algorithm>
#include <iostream>

using namespace std;

int main()
{
    vector<int> v1;
    vector<int>::iterator Iter;

    int i;
    for (i = 0; i <= 5; i++)
    {
        v1.push_back(5 * i);
    }

    cout << "The vector v1 = ( ";
    for (Iter = v1.begin(); Iter != v1.end(); Iter++)
        cout << *Iter << " ";
    cout << ")" << endl;

    // Count the number of integers > 10 in the vector
    vector<int>::iterator::difference_type result1;
    result1 = count_if(v1.begin(), v1.end(),
        binder1st<less<int> >(less<int>(), 10));
    cout << "The number of elements in v1 greater than 10 is: "
         << result1 << "." << endl;

    // Compare use of binder2nd fixing 2nd argument:
    // count the number of integers < 10 in the vector
    vector<int>::iterator::difference_type result2;
    result2 = count_if(v1.begin(), v1.end(),
        binder2nd<less<int> >(less<int>(), 10));
    cout << "The number of elements in v1 less than 10 is: "
         << result2 << "." << endl;
}
The vector v1 = ( 0 5 10 15 20 25 )
The number of elements in v1 greater than 10 is: 3.
The number of elements in v1 less than 10 is: 2.