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* )
Definido en el encabezado <functional>
template < class Predicate >
std:: unary_negate < Predicate > not1 ( const Predicate & pred ) ;
(hasta C++14)
template < class Predicate >
constexpr std:: unary_negate < Predicate > not1 ( const Predicate & pred ) ;
(desde C++14)
(obsoleto en C++17)
(eliminado en C++20)

std::not1 es una función auxiliar para crear un objeto función que devuelve el complemento del predicado unario pasado. El objeto función creado es de tipo std:: unary_negate < Predicate > .

El tipo de predicado unario debe definir un tipo miembro, argument_type , que sea convertible al tipo de parámetro del predicado. Los objetos de función unaria obtenidos de std::ref , std::cref , std::negate , std::logical_not , std::mem_fn , std::function , std::hash , o de otra llamada a std::not1 tienen este tipo definido, al igual que los objetos de función derivados del obsoleto std::unary_function .

Contenidos

Parámetros

pred - predicado unario

Valor de retorno

std::not1 devuelve un objeto de tipo std:: unary_negate < Predicate > , construido con pred .

Excepciones

(ninguno)

Ejemplo

#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';
    // lo mismo que arriba usando 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';
}

Salida:

3
1

Véase también

(C++17)
crea un objeto función que devuelve el complemento del resultado del objeto función que contiene
(plantilla de función)
(obsoleto en C++17) (eliminado en C++20)
objeto función contenedor que devuelve el complemento del predicado unario que contiene
(plantilla de clase)
(C++11)
contenedor copiable de cualquier objeto invocable construible por copia
(plantilla de clase)
contenedor solo-movimiento de cualquier objeto invocable que soporta calificadores en una signatura de llamada dada
(plantilla de clase)
(obsoleto en C++17) (eliminado en C++20)
construye objeto personalizado std::binary_negate
(plantilla de función)
(obsoleto en C++11) (eliminado en C++17)
crea un contenedor de objeto función compatible con adaptadores a partir de un puntero a función
(plantilla de función)
(obsoleto en C++11) (eliminado en C++17)
clase base de función unaria compatible con adaptadores
(plantilla de clase)