Namensräume
Varianten
Aktionen

std::negate<void>

Von cppreference.com
< cpp‎ | utility‎ | functional
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
 
Funktionsobjekte
Funktionsaufruf
(C++17)(C++23)
Identitätsfunktions-Objekt
(C++20)
Transparente Operator-Wrapper
(C++14)
(C++14)
negate<>
(C++14)
(C++14)  
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)

Alte Binder und Adaptoren
(bis C++17*)
(bis C++17*)
(bis C++17*)
(bis C++17*)
(bis C++17*)(bis C++17*)(bis C++17*)(bis C++17*)
(bis C++20*)
(bis C++20*)
(bis C++17*)(bis C++17*)
(bis C++17*)(bis C++17*)

(bis C++17*)
(bis C++17*)(bis C++17*)(bis C++17*)(bis C++17*)
(bis C++20*)
(bis C++20*)
 
Definiert in der Header-Datei <functional>
template<>
class negate<void>;
(seit C++14)

std::negate<> ist eine Spezialisierung von std::negate mit abgeleitetem Parameter- und Rückgabetyp.

Inhalt

[bearbeiten] Member types

Typ Definition
is_transparent nicht spezifiziert

[bearbeiten] Member functions

operator()
gibt ihr negiertes Argument zurück
(öffentliche Memberfunktion)

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

template< class T >

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

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

Gibt das Ergebnis der Negation von arg zurück.

Parameter

arg - zu negierender Wert

Rückgabewert

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

[bearbeiten] Beispiel

#include <complex>
#include <functional>
#include <iostream>
 
int main()
{
    auto complex_negate = std::negate<void>{}; // “void” can be omitted
    constexpr std::complex z(4, 2);
    std::cout << z << '\n';
    std::cout << -z << '\n';
    std::cout << complex_negate(z) << '\n';
}

Ausgabe

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