binder2nd Class
単項演算子関数オブジェクトにある値へバイナリ関数の 2 番目の引数をバインドすることにより、バイナリ関数オブジェクトを変換するコンストラクターを提供するテンプレート クラス。
template<class Operation>
class binder2nd
: public unary_function <
typename Operation::first_argument_type,
typename Operation::result_type>
{
public:
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;
protected:
Operation op;
typename Operation::second_argument_type value;
};
パラメーター
_Func
単項演算子関数オブジェクトに変換するバイナリの関数オブジェクト。_Right
バイナリの関数オブジェクトの 2 番目の引数をバインドする値。_Left
同期されたバイナリ オブジェクトが 2 番目の引数の固定値と比較する引数の値。
戻り値
単項の関数オブジェクト。バインディングの結果値 _Right.へのバイナリの関数オブジェクトの 2 番目の引数
解説
このテンプレート クラスは opなバイナリの関数オブジェクトの _Func のコピー、および [value]の _Right のコピーを格納します。これは op (_Left、[value]) を返すようにメンバー関数 operator() を定義します。
_Func が [操作] 型のオブジェクトであり、c が定数である場合、bind2nd ( _Func、c ) は binder2nd クラスのコンストラクター binder2nd<[操作]> と同等 ( _Func、c ) と方が便利です。
使用例
// 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;
}
必要条件
ヘッダー : <functional>
名前空間: std