Difference between revisions of "cpp/utility/functional/logical not"
From cppreference.com
< cpp | utility | functional
m (Text replace - "(===\s*Exceptions?\s*===\s+)\(none\)" to "{{cpp/impldef exception}}") |
m (~) |
||
(5 intermediate revisions by 3 users not shown) | |||
Line 2: | Line 2: | ||
{{cpp/utility/functional/navbar}} | {{cpp/utility/functional/navbar}} | ||
{{dcl begin}} | {{dcl begin}} | ||
− | {{dcl header | functional }} | + | {{dcl header|functional}} |
{{dcl rev begin}} | {{dcl rev begin}} | ||
− | {{dcl | until=c++14 | | + | {{dcl|until=c++14| |
template< class T > | template< class T > | ||
struct logical_not; | struct logical_not; | ||
}} | }} | ||
− | {{dcl | since=c++14 | | + | {{dcl|since=c++14| |
template< class T {{=}} void > | template< class T {{=}} void > | ||
struct logical_not; | struct logical_not; | ||
Line 19: | Line 19: | ||
===Specializations=== | ===Specializations=== | ||
{{rev begin}} | {{rev begin}} | ||
− | {{rev | since=c++14 | | + | {{rev|since=c++14| |
The standard library provides a specialization of {{tt|std::logical_not}} when {{tt|T}} is not specified, which leaves the parameter types and return type to be deduced. | The standard library provides a specialization of {{tt|std::logical_not}} when {{tt|T}} is not specified, which leaves the parameter types and return type to be deduced. | ||
{{dsc begin}} | {{dsc begin}} | ||
− | {{dsc inc | cpp/utility/functional/dsc logical_not_void}} | + | {{dsc inc|cpp/utility/functional/dsc logical_not_void}} |
{{dsc end}} | {{dsc end}} | ||
}} | }} | ||
Line 31: | Line 31: | ||
===Member functions=== | ===Member functions=== | ||
{{dsc begin}} | {{dsc begin}} | ||
− | {{dsc mem fun | operator() | nolink=true | returns the logical NOT of the argument}} | + | {{dsc mem fun|operator()|nolink=true|returns the logical NOT of the argument}} |
{{dsc end}} | {{dsc end}} | ||
− | {{member | {{small|std::logical_not::}}operator() | 2= | + | {{member|{{small|std::logical_not::}}operator()|2= |
{{dcl begin}} | {{dcl begin}} | ||
− | {{ | + | {{dcla|constexpr=c++14|1= |
− | + | ||
bool operator()( const T& arg ) const; | bool operator()( const T& arg ) const; | ||
}} | }} | ||
− | |||
− | |||
− | |||
− | |||
{{dcl end}} | {{dcl end}} | ||
− | Returns the logical NOT of {{ | + | Returns the logical NOT of {{c|arg}}. |
===Parameters=== | ===Parameters=== | ||
{{par begin}} | {{par begin}} | ||
− | {{par | arg | value to compute logical NOT of}} | + | {{par|arg|value to compute logical NOT of}} |
{{par end}} | {{par end}} | ||
Line 59: | Line 54: | ||
===Possible implementation=== | ===Possible implementation=== | ||
− | {{eq fun | 1= | + | {{eq fun|1= |
− | + | constexpr // since C++14 | |
+ | bool operator()(const T& arg) const | ||
{ | { | ||
return !arg; | return !arg; | ||
Line 67: | Line 63: | ||
}} | }} | ||
− | + | {{langlinks|de|es|fr|it|ja|pt|ru|zh}} | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + |
Latest revision as of 21:17, 13 July 2024
Defined in header <functional>
|
||
template< class T > struct logical_not; |
(until C++14) | |
template< class T = void > struct logical_not; |
(since C++14) | |
Function object for performing logical NOT (logical negation). Effectively calls operator! for type T
.
Contents |
[edit] Specializations
The standard library provides a specialization of
|
(since C++14) |
[edit] Member types
Type | Definition |
result_type (deprecated in C++17)(removed in C++20)
|
bool |
argument_type (deprecated in C++17)(removed in C++20)
|
T
|
These member types are obtained via publicly inheriting std::unary_function<T, bool>. |
(until C++11) |
[edit] Member functions
operator() |
returns the logical NOT of the argument (public member function) |
std::logical_not::operator()
bool operator()( const T& arg ) const; |
(constexpr since C++14) | |
Returns the logical NOT of arg.
Parameters
arg | - | value to compute logical NOT of |
Return value
The result of !arg.
[edit] Exceptions
May throw implementation-defined exceptions.
Possible implementation
constexpr // since C++14 bool operator()(const T& arg) const { return !arg; } |