Namespaces
Variants

std:: not1

From cppreference.net
Utilities library
Function objects
Function invocation
(C++17) (C++23)
Identity function object
(C++20)
Old binders and adaptors
( until C++17* )
( until C++17* )
( until C++17* )
( until C++17* )
( until C++17* ) ( until C++17* ) ( until C++17* ) ( until C++17* )
not1
( until C++20* )
( until C++20* )
( until C++17* ) ( until C++17* )
( until C++17* ) ( until C++17* )

( until C++17* )
( until C++17* ) ( until C++17* ) ( until C++17* ) ( until C++17* )
( until C++20* )
( until C++20* )
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)
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)