Namespaces
Variants

std:: negate<void>

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* )
( 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* )
Défini dans l'en-tête <functional>
template <>
class negate < void > ;
(depuis C++14)

std:: negate <> est une spécialisation de std::negate avec le type de paramètre et de retour déduit.

Table des matières

Types membres

Type Définition
is_transparent unspecified

Fonctions membres

operator()
retourne son argument négatif
(fonction membre publique)

std::negate<void>:: operator()

template < class T >

constexpr auto operator ( ) ( T && arg ) const

- > decltype ( - std:: forward < T > ( arg ) ) ;

Retourne le résultat de la négation de arg .

Paramètres

arg - valeur à négationner

Valeur de retour

- std:: forward < T > ( arg ) .

Exemple

#include <complex>
#include <functional>
#include <iostream>
int main()
{
    auto complex_negate = std::negate<void>{}; // "void" peut être omis
    constexpr std::complex z(4, 2);
    std::cout << z << '\n';
    std::cout << -z << '\n';
    std::cout << complex_negate(z) << '\n';
}

Sortie :

(4,2)
(-4,-2)
(-4,-2)