Пространства имён
Варианты
Действия

std::binary_function

Материал из cppreference.com
< cpp‎ | utility‎ | functional
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, RTTI)
Макросы тестирования функциональности библиотеки (C++20)    
Управление динамической памятью
Программные утилиты
Поддержка сопрограмм (C++20)
Вариативные функции
Трёхстороннее сравнение (C++20)
(C++20)
(C++20)(C++20)(C++20)(C++20)(C++20)(C++20)
Общие утилиты
Дата и время
Функциональные объекты
Библиотека форматирования (C++20)
(C++11)
Операторы отношения (устарело в C++20)
Целочисленные функции сравнения
(C++20)(C++20)(C++20)    
(C++20)
Операции обмена и типа
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Общие лексические типы
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
Элементарные преобразования строк
(C++17)
(C++17)
 
Объекты функции
Функции обёртки
(C++11)
(C++11)
Применение частичных функций
(C++20)(C++23)
(C++11)
Вызов функции
(C++17)(C++23)
Объект идентичности функции
(C++20)
Обёртки ссылок
(C++11)(C++11)
Прозрачные обёртки операторов
(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)

Отрицатели
(C++17)
Искатели
Ограниченные компараторы
Старые привязки и адаптеры
(до C++17*)
binary_function
(до C++17*)
(до C++17*)
(до C++17*)
(до C++17*)(до C++17*)(до C++17*)(до C++17*)
(до C++20*)
(до C++20*)
(до C++17*)(до C++17*)
(до C++17*)(до C++17*)

(до C++17*)
(до C++17*)(до C++17*)(до C++17*)(до C++17*)
(до C++20*)
(до C++20*)
 
Определено в заголовочном файле <functional>
template<

    class Arg1,
    class Arg2,
    class Result

> struct binary_function;
(устарело в 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++11)(удалено в C++17)
создаёт совместимую с адаптером обёртку функционального объекта из указателя на функцию
(шаблон функции) [править]
(устарело в C++11)(удалено в C++17)
совместимая с адаптером обёртка для указателя на бинарную функцию
(шаблон класса) [править]
(устарело в C++11)(удалено в C++17)
совместимый с адаптором базовый класс унарной функции
(шаблон класса) [править]