std:: not2
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Old binders and adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
Definiert im Header
<functional>
|
||
|
template
<
class
Predicate
>
std:: binary_negate < Predicate > not2 ( const Predicate & pred ) ; |
(bis C++14) | |
|
template
<
class
Predicate
>
constexpr std:: binary_negate < Predicate > not2 ( const Predicate & pred ) ; |
(seit C++14)
(veraltet in C++17) (entfernt in C++20) |
|
std::not2
ist eine Hilfsfunktion zur Erstellung eines Funktionsobjekts, das das Komplement der übergebenen binären Prädikatfunktion zurückgibt. Das erstellte Funktionsobjekt ist vom Typ
std::
binary_negate
<
Predicate
>
.
Der binäre Prädikattyp muss zwei Membertypen definieren,
first_argument_type
und
second_argument_type
, die in die Parametertypen des Prädikats konvertierbar sind. Die Funktionsobjekte, die von
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
oder von einem weiteren Aufruf von
std::not2
abgeleitet sind, haben diese Typen definiert, ebenso wie Funktionsobjekte, die von dem veralteten
std::binary_function
abgeleitet sind.
Inhaltsverzeichnis |
Parameter
| pred | - | binäres Prädikat |
Rückgabewert
std::not2
gibt ein Objekt vom Typ
std::
binary_negate
<
Predicate
>
zurück, konstruiert mit
pred
.
Exceptions
(keine)
Beispiel
#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 << "Negierung eines 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 << "Negieren eines Standard-Funktors:\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 << "Negieren einer 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 << "Negieren eines 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'; }
Ausgabe:
Negieren einer binary_function: 0 2 true 1 1 false 2 0 true Negieren eines Standard-Funktors: 0 2 true 1 1 false 2 0 true Negieren einer std::function: 0 2 true 1 1 false 2 0 true Negieren eines std::reference_wrapper: 0 2 true 1 1 false 2 0 true
Siehe auch
|
(C++17)
|
Erstellt ein Funktionsobjekt, das das Komplement des Ergebnisses des von ihm gehaltenen Funktionsobjekts zurückgibt
(Funktions-Template) |
|
(veraltet in C++17)
(entfernt in C++20)
|
Wrapper-Funktionsobjekt, das das Komplement des von ihm gehaltenen binären Prädikats zurückgibt
(Klassen-Template) |
|
(C++11)
|
Kopierbarer Wrapper eines beliebigen kopierkonstruierbaren aufrufbaren Objekts
(Klassen-Template) |
|
(C++23)
|
Nur-verschiebbarer Wrapper eines beliebigen aufrufbaren Objekts, das Qualifizierer in einer gegebenen Aufrufsignatur unterstützt
(Klassen-Template) |
|
(veraltet in C++17)
(entfernt in C++20)
|
Konstruiert ein benutzerdefiniertes
std::unary_negate
Objekt
(Funktions-Template) |
|
(veraltet in C++11)
(entfernt in C++17)
|
Erstellt einen adapterkompatiblen Funktionsobjekt-Wrapper aus einem Funktionszeiger
(Funktions-Template) |
|
(veraltet in C++11)
(entfernt in C++17)
|
Adapterkompatible Basisklasse für binäre Funktionen
(Klassen-Template) |