Share via


unary_negate, classe

Modèle de classe fournissant une fonction membre qui annule la valeur de retour d’une fonction unaire spécifiée. Déconseillé en C++17 en faveur de not_fn.

Syntaxe

template <class Predicate>
class unary_negate
    : public unaryFunction<typename Predicate::argument_type, bool>
{
    explicit unary_negate(const Predicate& Func);
    bool operator()(const typename Predicate::argument_type& left) const;
};

Paramètres

Func
Fonction unaire à inverser.

left
Opérande de la fonction unaire à inverser.

Valeur de retour

Négation de la fonction unaire.

Notes

Le modèle de classe stocke une copie d’un objet de fonction unaire _Func. Il définit sa fonction operator() membre comme retournant !_Func(left).

Le constructeur de unary_negate est rarement utilisé directement. La fonction d’assistance not1 simplifie la manière de déclarer et d’utiliser le prédicat de l’adaptateur unary_negator.

Exemple

// functional_unary_negate.cpp
// compile with: /EHsc
#include <vector>
#include <functional>
#include <algorithm>
#include <iostream>

using namespace std;

int main()
{
    vector<int> v1;
    vector<int>::iterator Iter;

    int i;
    for (i = 0; i <= 7; i++)
    {
        v1.push_back(5 * i);
    }

    cout << "The vector v1 = ( ";
    for (Iter = v1.begin(); Iter != v1.end(); Iter++)
        cout << *Iter << " ";
    cout << ")" << endl;

    vector<int>::iterator::difference_type result1;
    // Count the elements greater than 10
    result1 = count_if(v1.begin(), v1.end(), bind2nd(greater<int>(), 10));
    cout << "The number of elements in v1 greater than 10 is: "
         << result1 << "." << endl;

    vector<int>::iterator::difference_type result2;
    // Use the negator to count the elements less than or equal to 10
    result2 = count_if(v1.begin(), v1.end(),
        unary_negate<binder2nd <greater<int> > >(bind2nd(greater<int>(),10)));

    // The following helper function not1 also works for the above line
    // not1(bind2nd(greater<int>(), 10)));

    cout << "The number of elements in v1 not greater than 10 is: "
         << result2 << "." << endl;
}
The vector v1 = ( 0 5 10 15 20 25 30 35 )
The number of elements in v1 greater than 10 is: 5.
The number of elements in v1 not greater than 10 is: 3.