Scroll to navigation

std::negate(3) C++ Standard Libary std::negate(3)

NAME

std::negate - std::negate

Synopsis


Defined in header <functional>
template<> (since C++14)
class negate<void>;


std::negate<> is a specialization of std::negate with parameter and return type
deduced.

Member types


Member type Definition
is_transparent /* unspecified */

Member functions


operator() returns its negated argument
(public member function)

std::negate<>::operator()


template< class T >


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


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


Returns the result of negating arg (or whatever the unary operator- is overloaded to
do)

Parameters


arg - value to negate

Return value


The result of -arg.

Notes


The member type is_transparent indicates to the caller that this function object is
a transparent function object: it accepts arguments of arbitrary types and uses
perfect forwarding, which avoids unnecessary copying and conversion when the
function object is used in heterogeneous context, or with rvalue arguments. In
particular, template functions such as std::set::find and std::set::lower_bound make
use of this member type on their Compare types.

Example

// Run this code


#include <complex>
#include <functional>
#include <iostream>


int main()
{
constexpr std::complex z(4, 2);


std::cout << z << ' ' << -z << ' ' << std::negate{}(z) << '\n';
}

Output:


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

2022.07.31 http://cppreference.com