GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

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

std::negate - std::negate


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 type Definition
is_transparent /* unspecified */


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)


arg - value to negate


The result of -arg.


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.

// 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';
}


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

2022.07.31 http://cppreference.com

Search for    or go to Top of page |  Section 3 |  Main Index

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with ManDoc.