std::binary_function - cppreference.com (original) (raw)

| | | | | -------------------------------------------------------------------------- | | ---------------------------------------- | | template< class Arg1, class Arg2, class Result > struct binary_function; | | (deprecated in C++11) (removed in C++17) |

std::binary_function is a base class for creating function objects with two arguments.

std::binary_function does not define operator(); it is expected that derived classes will define this. std::binary_function provides only three types - first_argument_type, second_argument_type and result_type - defined by the template parameters.

Some standard library function object adaptors, such as std::not2, require the function objects they adapt to have certain types defined; std::not2 requires the function object being adapted to have two types named first_argument_type and second_argument_type. Deriving function objects that take two arguments from std::binary_function is an easy way to make them compatible with those adaptors.

std::binary_function is deprecated in C++11 and removed in C++17.

[edit] Member types

Type Definition
first_argument_type Arg1
second_argument_type Arg2
result_type Result

[edit] Example

#include #include #include #include   struct same : std::binary_function<int, int, bool> { bool operator()(int a, int b) const { return a == b; } };   int main() { std::vector v1{'A', 'B', 'C', 'D', 'E'}; std::vector v2{'E', 'D', 'C', 'B', 'A'}; std::vector 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'; }

Output:

A != E : true B != D : true C != C : false D != B : true E != A : true

[edit] See also

| | copyable wrapper of any copy constructible callable object (class template) [edit] | | | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | | | move-only wrapper of any callable object that supports qualifiers in a given call signature (class template) [edit] | | | (deprecated in C++11)(removed in C++17) | creates an adaptor-compatible function object wrapper from a pointer to function (function template) [edit] | | (deprecated in C++11)(removed in C++17) | adaptor-compatible wrapper for a pointer to binary function (class template) [edit] | | (deprecated in C++11)(removed in C++17) | adaptor-compatible unary function base class (class template) [edit] |