Namespaces
Variants

std:: not2

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