std:: not1
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Old binders and adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
Definiert in Header
<functional>
|
||
|
template
<
class
Predicate
>
std:: unary_negate < Predicate > not1 ( const Predicate & pred ) ; |
(bis C++14) | |
|
template
<
class
Predicate
>
constexpr std:: unary_negate < Predicate > not1 ( const Predicate & pred ) ; |
(seit C++14)
(veraltet in C++17) (entfernt in C++20) |
|
std::not1
ist eine Hilfsfunktion zur Erstellung eines Funktionsobjekts, das das Komplement der übergebenen unären Prädikatfunktion zurückgibt. Das erstellte Funktionsobjekt ist vom Typ
std::
unary_negate
<
Predicate
>
.
Der unäre Prädikattyp muss einen Membertyp
argument_type
definieren, der in den Parametertyp des Prädikats konvertierbar ist. Die unären Funktionsobjekte, die von
std::ref
,
std::cref
,
std::negate
,
std::logical_not
,
std::mem_fn
,
std::function
,
std::hash
oder von einem weiteren Aufruf von
std::not1
stammen, haben diesen Typ definiert, ebenso wie Funktionsobjekte, die vom veralteten
std::unary_function
abgeleitet sind.
Inhaltsverzeichnis |
Parameter
| pred | - | unäres Prädikat |
Rückgabewert
std::not1
gibt ein Objekt vom Typ
std::
unary_negate
<
Predicate
>
zurück, konstruiert mit
pred
.
Ausnahmen
(keine)
Beispiel
#include <algorithm> #include <functional> #include <iostream> #include <iterator> #include <numeric> #include <vector> struct LessThan7 : std::unary_function<int, bool> { bool operator()(int i) const { return i < 7; } }; int main() { std::vector<int> v(10); std::iota(std::begin(v), std::end(v), 0); std::cout << std::count_if(begin(v), end(v), std::not1(LessThan7())) << '\n'; // dasselbe wie oben mit std::function std::function<bool(int)> less_than_9 = [](int x) { return x < 9; }; std::cout << std::count_if(begin(v), end(v), std::not1(less_than_9)) << '\n'; }
Ausgabe:
3 1
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 unären Prädikats zurückgibt, das es hält
(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::binary_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 unäre Funktionen
(Klassen-Template) |