binder2nd 클래스
이진 함수의 두 번째 인수를 지정된 값에 바인딩하여 이진 함수 개체를 단항 함수 개체로 변환하는 생성자를 제공하는 클래스 템플릿입니다. C++11에서 사용되지 않으며 C++17에서 제거되었습니다.
구문
template <class Operation>
class binder2nd
: public unaryFunction <typename Operation::first_argument_type,
typename Operation::result_type>
{
typedef typename Operation::argument_type argument_type;
typedef typename Operation::result_type result_type;
binder2nd(
const Operation& func,
const typename Operation::second_argument_type& right);
result_type operator()(const argument_type& left) const;
result_type operator()(argument_type& left) const;
};
매개 변수
func
단항 함수 개체로 변환할 이항 함수 개체입니다.
right
이항 함수 개체의 두 번째 인수가 바인딩되는 값입니다.
left
수정된 이진 개체를 두 번째 인수의 고정 값과 비교하는 인수의 값입니다.
반환 값
이진 함수 개체의 두 번째 인수를 오른쪽 값에 바인딩한 결과인 단항 함수 개체입니다.
설명
클래스 템플릿은 이진 함수 개체 funcop
의 복사본을 저장하고 오른쪽의 복사본을 저장합니다value
. 해당 멤버 함수 operator()
를 반환으로 정의합니다 op(left, value)
.
func가 형식 Operation
의 개체이고 c가 상수인 경우 bind2nd(func, c)
는 클래스 생성자와 binder2nd<Operation>(func, c)
동일 binder2nd
하며 더 편리합니다.
예제
// functional_binder2nd.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(),
binder2nd<greater<int> >(greater<int>(), 10));
cout << "The number of elements in v1 greater than 10 is: "
<< result1 << "." << endl;
// Compare using binder1st fixing 1st argument:
// count the number of integers < 10 in the vector
vector<int>::iterator::difference_type result2;
result2 = count_if(v1.begin(), v1.end(),
binder1st<greater<int> >(greater<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.