binary_negate クラス
指定した二項関数の戻り値を否定するメンバー関数を提供するクラス テンプレート。 not_fn を優先するため、C++17 では非推奨となりました。
構文
template <class Operation>
class binary_negate
: public binaryFunction <typename Operation::first_argument_type,
typename Operation::second_argument_type, bool>
{
explicit binary_negate(const Operation& Func);
bool operator()(const typename Operation::first_argument_type& left,
const typename Operation::second_argument_type& right) const;
};
パラメーター
Func
否定する二項関数。
left
否定する二項関数の左オペランド。
right
否定する二項関数の右オペランド。
戻り値
二項関数の否定。
解説
このクラス テンプレートは、二項関数オブジェクト Func のコピーを格納します。 そのメンバー関数 operator()
は !Func(left, right)
を返すように定義されています。
binary_negate
のコンストラクターが直接使用されることはほとんどありません。 binary_negator アダプター述語を宣言し、使用するとき、通常、ヘルパー関数 not2 が選択されます。
例
// functional_binary_negate.cpp
// compile with: /EHsc
#define _CRT_RAND_S
#include <stdlib.h>
#include <vector>
#include <algorithm>
#include <functional>
#include <iostream>
int main( )
{
using namespace std;
vector <unsigned int> v1;
vector <unsigned int>::iterator Iter1;
unsigned int i;
v1.push_back( 6262 );
v1.push_back( 6262 );
unsigned int randVal = 0;
for ( i = 0 ; i < 5 ; i++ )
{
rand_s(&randVal);
v1.push_back( randVal );
}
cout << "Original vector v1 = ( " ;
for ( Iter1 = v1.begin( ) ; Iter1 != v1.end( ) ; Iter1++ )
cout << *Iter1 << " ";
cout << ")" << endl;
// To sort in ascending order,
// use default binary predicate less<unsigned int>( )
sort( v1.begin( ), v1.end( ) );
cout << "Sorted vector v1 = ( " ;
for ( Iter1 = v1.begin( ) ; Iter1 != v1.end( ) ; Iter1++ )
cout << *Iter1 << " ";
cout << ")" << endl;
// To sort in descending order,
// use the binary_negate function
sort( v1.begin( ), v1.end( ),
binary_negate<less<unsigned int> >(less<unsigned int>( ) ) );
// The helper function not2 could also have been used
// in the above line and is usually preferred for convenience
// sort( v1.begin( ), v1.end( ), not2(less<unsigned int>( ) ) );
cout << "Resorted vector v1 = ( " ;
for ( Iter1 = v1.begin( ) ; Iter1 != v1.end( ) ; Iter1++ )
cout << *Iter1 << " ";
cout << ")" << endl;
}
Original vector v1 = ( 6262 6262 2233879413 2621500314 580942933 3715465425 3739828298 )
Sorted vector v1 = ( 6262 6262 580942933 2233879413 2621500314 3715465425 3739828298 )
Resorted vector v1 = ( 3739828298 3715465425 2621500314 2233879413 580942933 6262 6262 )