std::not2
From cppreference.com
< cpp | utility | functional
| ヘッダ <functional> で定義 |
||
| template< class Predicate > std::binary_negate<Predicate> not2( const Predicate& pred ); |
(C++14まで) | |
| template< class Predicate > constexpr std::binary_negate<Predicate> not2( const Predicate& pred ); |
(C++14以降) (C++17で非推奨) (C++20で削除) |
|
std::not2 は、引数として渡された二項述語関数の否定を返す関数オブジェクトを作成するためのヘルパー関数です。作成される関数オブジェクトの型は std::binary_negate<Predicate> です。
二項述語の型は、述語のパラメータ型に変換可能な first_argument_type と second_argument_type という2つのメンバ型を定義する必要があります。std::owner_less、std::ref、std::cref、std::plus、std::minus、std::multiplies、std::divides、std::modulus、std::equal_to、std::not_equal_to、std::greater、std::less、std::greater_equal、std::less_equal、std::logical_not、std::logical_or、std::bit_and、std::bit_or、std::bit_xor、std::mem_fn、std::map::value_comp、std::multimap::value_comp、std::function、または std::not2 の別の呼び出しから得られる関数オブジェクト、および非推奨の std::binary_function から派生した関数オブジェクトは、これらの型を定義しています。
目次 |
[編集] パラメータ
| pred | - | 二項述語 |
[編集] 戻り値
std::not2 は、pred を使用して構築された、std::binary_negate<Predicate> 型のオブジェクトを返します。
[編集] 例外
(なし)
[編集] 例
このコードを実行
#include <algorithm> #include <cstddef> #include <functional> #include <iostream> #include <vector> struct old_same : std::binary_function<int, int, bool> { bool operator()(int a, int b) const { return a == b; } }; struct new_same { bool operator()(int a, int b) const { return a == b; } }; bool same_fn(int a, int b) { return a == b; } int main() { std::vector<int> v1{0, 1, 2}; std::vector<int> v2{2, 1, 0}; std::vector<bool> v3(v1.size()); std::cout << "negating a binary_function:\n"; std::transform(v1.begin(), v1.end(), v2.begin(), v3.begin(), std::not2(old_same())); std::cout << std::boolalpha; for (std::size_t i = 0; i < v1.size(); ++i) std::cout << v1[i] << ' ' << v2[i] << ' ' << v3[i] << '\n'; std::cout << "negating a standard functor:\n"; std::transform(v1.begin(), v1.end(), v2.begin(), v3.begin(), std::not2(std::equal_to<int>())); for (std::size_t i = 0; i < v1.size(); ++i) std::cout << v1[i] << ' ' << v2[i] << ' ' << v3[i] << '\n'; std::cout << "negating a std::function:\n"; std::transform(v1.begin(), v1.end(), v2.begin(), v3.begin(), std::not2(std::function<bool(int, int)>(new_same()))); for (std::size_t i = 0; i < v1.size(); ++i) std::cout << v1[i] << ' ' << v2[i] << ' ' << v3[i] << '\n'; std::cout << "negating a std::reference_wrapper:\n"; std::transform(v1.begin(), v1.end(), v2.begin(), v3.begin(), std::not2(std::ref(same_fn))); for (std::size_t i = 0; i < v1.size(); ++i) std::cout << v1[i] << ' ' << v2[i] << ' ' << v3[i] << '\n'; }
出力
negating a binary_function: 0 2 true 1 1 false 2 0 true negating a standard functor: 0 2 true 1 1 false 2 0 true negating a std::function: 0 2 true 1 1 false 2 0 true negating a std::reference_wrapper: 0 2 true 1 1 false 2 0 true
[編集] 関連項目
| (C++17) |
保持する関数オブジェクトの結果の補数を返す関数オブジェクトを作成する (関数テンプレート) |
| (C++17で非推奨)(C++20で削除) |
保持する二項述語の補数を返すラッパー関数オブジェクト (クラステンプレート) |
| (C++11) |
コピー構築可能な任意の呼び出し可能オブジェクトをラップするコピー可能なラッパー (クラステンプレート) |
| (C++23) |
与えられた呼び出しシグネチャで修飾子をサポートする任意の呼び出し可能オブジェクトのムーブ専用ラッパー (クラステンプレート) |
| (C++17で非推奨)(C++20で削除) |
カスタムの std::unary_negate オブジェクトを構築する (関数テンプレート) |
| (C++11で非推奨)(C++17で削除) |
関数へのポインタからアダプタ互換の関数オブジェクトラッパーを生成する (関数テンプレート) |
| (C++11で非推奨)(C++17で削除) |
アダプタ互換の二項関数基底クラス (クラステンプレート) |