std::bind1st, std::bind2nd
Материал из cppreference.com
< cpp | utility | functional
Определено в заголовочном файле <functional>
|
||
template< class F, class T > std::binder1st<F> bind1st( const F& f, const T& x ); |
(1) | (устарело в C++11) (удалено в C++17) |
template< class F, class T > std::binder2nd<F> bind2nd( const F& f, const T& x ); |
(2) | (устарело в C++11) (удалено в C++17) |
Связывает заданный аргумент x
с первым или вторым параметром данного объекта бинарной функции f
. То есть сохраняет x
в результирующей оболочке, которая при вызове передаёт x
в качестве первого или второго параметра f
.
1) Связывает первый аргумент
f
с x
. Эффективно вызывает std::binder1st<F>(f, typename F::first_argument_type(x)).2) Связывает второй аргумент
f
с x
. Эффективно вызывает std::binder2nd<F>(f, typename F::second_argument_type(x)).Содержание |
[править] Параметры
f | — | указатель на функцию для привязки аргумента |
x | — | аргумент для привязки к f
|
[править] Возвращаемое значение
Функциональный объект, обёртывающий f
и x
.
[править] Исключения
Может генерировать исключения, определённые реализацией.
[править] Пример
Запустить этот код
#include <iostream> #include <iomanip> #include <algorithm> #include <functional> #include <cmath> #include <cstddef> #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); // начиная с C++20 используйте std::numbers::pi std::transform(a.begin(), a.end(), r.begin(), std::bind1st(std::multiplies<double>(), pi / 180.)); // эквивалентная лямбда: [pi](double a){ return a*pi / 180.; }); for(std::size_t n = 0; n < a.size(); ++n) std::cout << std::setw(3) << a[n] << "° = " << std::fixed << r[n] << " радиан\n" << std::defaultfloat; }
Вывод:
0° = 0.000000 радиан 30° = 0.523599 радиан 45° = 0.785398 радиан 60° = 1.047198 радиан 90° = 1.570796 радиан 180° = 3.141593 радиан
[править] Смотрите также
(устарело в C++11)(удалено в C++17) |
объект функции, содержащий бинарную функцию и один из её аргументов (шаблон класса) |
(C++20)(C++23) |
связывает переменное количество аргументов по порядку с объектом функцией (шаблон функции) |