std::binary_function — cppreference.com
Материал из cppreference.com
<tbody> </tbody>
|
|
(устарело в C++11) (удалено в C++17) |
|
std::binary_function это базовый класс для создания объектов-функций с двумя аргументами.
std::binary_function не определяет operator(); ожидается, что его будут определять производные классы. std::binary_function предоставляет только три типа first_argument_type, second_argument_type и result_type, определяемые параметрами шаблона.
Некоторые адаптеры объектов функций стандартной библиотеки, такие как std::not2, требуют, чтобы объекты функций, которые они адаптируют, имели некоторые определённые типы; std::not2 требует, чтобы адаптируемый объект функции имел два типа с именами first_argument_type и second_argument_type. Получение объектов-функций, принимающих два аргумента из std::binary_function, это простой способ сделать их совместимыми с этими адаптерами.
std::binary_function устарела в C++11 и удалена в C++17.
Типы элементы
| Тип | Определение |
first_argument_type
|
Arg1
|
second_argument_type
|
Arg2
|
result_type
|
Result
|
Пример
#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'; }
Вывод:
A != E : true B != D : true C != C : false D != B : true E != A : true
Смотрите также
| обёртывает вызываемый объект любого конструируемого копированием типа с указанной сигнатурой вызова функции (шаблон класса) [править] | |
| обёртывает вызываемый объект любого типа с указанной сигнатурой вызова функции (шаблон класса) [править] | |
(устарело в C++11)(удалено в C++17) |
создаёт совместимую с адаптером обёртку функционального объекта из указателя на функцию (шаблон функции) [править] |
(устарело в C++11)(удалено в C++17) |
совместимая с адаптером обёртка для указателя на бинарную функцию (шаблон класса) [править] |
(устарело в C++11)(удалено в C++17) |
совместимый с адаптором базовый класс унарной функции (шаблон класса) [править] |