std::unary_negate
| Definiert in der Header-Datei <functional> |
||
| template< class Predicate > struct unary_negate : public std::unary_function<Predicate::argument_type, bool>; |
(bis C++11) | |
| template< class Predicate > struct unary_negate; |
(seit C++11) (veraltet in C++17) (in C++20 entfernt) |
|
std::unary_negate ist ein Wrapper-Funktionsobjekt, das die Negation des von ihm gehaltenen unären Prädikats zurückgibt.
Der Typ des unären Prädikats muss einen Member-Typ namens argument_type definieren, der in den Parametertyp des Prädikats konvertierbar ist. Die von std::ref, std::cref, std::negate, std::logical_not, std::mem_fn, std::function, std::hash oder durch einen weiteren Aufruf von std::not1 erhaltene unäre Funktions-Objekte haben diesen Typ definiert, ebenso wie Funktionsobjekte, die vom veralteten std::unary_function abgeleitet sind.
std::unary_negate-Objekte werden einfach mit der Hilfsfunktion std::not1 konstruiert.
Inhalt |
[edit] Member types
| Typ | Definition |
argument_type
|
Predicate::argument_type |
result_type
|
bool |
[edit] Member functions
| (Konstruktor) |
konstruiert ein neues unary_negate-Objekt mit dem übergebenen Prädikat (öffentliche Memberfunktion) |
| operator() |
gibt das logische Komplement des Ergebnisses eines Aufrufs des gespeicherten Prädikats zurück (öffentliche Memberfunktion) |
std::unary_negate::unary_negate
| explicit unary_negate( Predicate const& pred ); |
(bis C++14) | |
| constexpr explicit unary_negate( Predicate const& pred ); |
(seit C++14) | |
Konstruiert ein std::unary_negate-Funktionsobjekt mit dem gespeicherten Prädikat pred.
Parameter
| pred | - | Prädikat-Funktionsobjekt |
std::unary_negate::operator()
| bool operator()( argument_type const& x ) const; |
(bis C++14) | |
| constexpr bool operator()( argument_type const& x ) const; |
(seit C++14) | |
Gibt die logische Negation des Ergebnisses des Aufrufs von pred(x) zurück.
Parameter
| x | - | Argument, das an das Prädikat weitergegeben wird |
Rückgabewert
Die logische Negation des Ergebnisses des Aufrufs von pred(x).
[edit] Example
#include <algorithm> #include <functional> #include <iostream> #include <vector> struct less_than_7 : std::unary_function<int, bool> { bool operator()(int i) const { return i < 7; } }; int main() { std::vector<int> v(7, 7); v[0] = v[1] = v[2] = 6; std::unary_negate<less_than_7> not_less_than_7((less_than_7())); // C++11 solution: // Use std::function<bool (int)> // std::function<bool (int)> not_less_than_7 = // [](int x)->bool { return !less_than_7()(x); }; std::cout << std::count_if(v.begin(), v.end(), not_less_than_7); }
Ausgabe
4
[edit] See also
| (in C++17 veraltet)(in C++20 entfernt) |
Wrapper-Funktionsobjekt, das die Negation (Komplement) des von ihm gehaltenen binären Prädikats zurückgibt (Klassenvorlage) |
| (C++11) |
kopierfähiger Wrapper für jedes kopierkonstruierbare aufrufbare Objekt (Klassen-Template) |
| (C++23) |
Move-only-Wrapper für jedes aufrufbare Objekt, das Qualifizierer in einer gegebenen Aufrufsignatur unterstützt (Klassen-Template) |
| (in C++17 veraltet)(in C++20 entfernt) |
konstruiert ein benutzerdefiniertes std::unary_negate-Objekt (Funktionsvorlage) |
| (in C++11 veraltet)(in C++17 entfernt) |
erstellt einen adaptor-kompatiblen Funktionsobjekt-Wrapper aus einem Funktionszeiger (Funktionsvorlage) |
| (in C++11 veraltet)(in C++17 entfernt) |
Adaptor-kompatible Basisklasse für unäre Funktionen (Klassenvorlage) |