Difference between revisions of "cpp/types/negation"
From cppreference.com
(LWG 2567) |
m (→Example: Applied `static_assert`) |
||
(14 intermediate revisions by 5 users not shown) | |||
Line 1: | Line 1: | ||
{{cpp/title|negation}} | {{cpp/title|negation}} | ||
− | {{cpp/ | + | {{cpp/meta/navbar}} |
{{dcl begin}} | {{dcl begin}} | ||
− | {{dcl header | type_traits}} | + | {{dcl header|type_traits}} |
− | {{dcl | since=c++17 | + | {{dcl|since=c++17|1= |
− | template<class B> | + | template< class B > |
struct negation; | struct negation; | ||
}} | }} | ||
{{dcl end}} | {{dcl end}} | ||
− | Forms the logical negation of the type trait {{ | + | Forms the [[enwiki:Negation|logical negation]] of the type trait {{c|B}}. |
− | The type {{c|std::negation<B>}} is a {{ | + | The type {{c|std::negation<B>}} is a {{named req|UnaryTypeTrait}} with a base characteristic of {{c|std::bool_constant<!bool(B::value)>}}. |
+ | |||
+ | {{cpp/types/nospec|pv}} | ||
===Template parameters=== | ===Template parameters=== | ||
{{par begin}} | {{par begin}} | ||
− | {{par | B | any type such that {{c|B::value}} is | + | {{par|B|any type such that the expression {{c|bool(B::value)}} is a valid constant expression }} |
{{par end}} | {{par end}} | ||
− | === Helper variable template === | + | ===Helper variable template=== |
− | {{ | + | {{ddcl|since=c++17|1= |
− | + | template< class B > | |
− | template<class B> | + | |
constexpr bool negation_v = negation<B>::value; | constexpr bool negation_v = negation<B>::value; | ||
}} | }} | ||
− | |||
− | {{cpp/types/integral_constant/inherit | {{tt|B}} has a member {{ | + | {{cpp/types/integral_constant/inherit|{{tt|B}} has a member {{c|::value}} that is {{c|false}} when explicitly converted to {{c|bool}}}} |
===Possible implementation=== | ===Possible implementation=== | ||
{{eq fun | {{eq fun | ||
− | + | |1= | |
template<class B> | template<class B> | ||
− | struct negation : std::bool_constant<!B::value> { }; | + | struct negation : std::bool_constant<!bool(B::value)> { }; |
}} | }} | ||
+ | |||
+ | ===Notes=== | ||
+ | {{feature test macro|__cpp_lib_logical_traits|std=C++17|value=201510L|[[cpp/meta#Operations on traits|Logical operator type traits]]}} | ||
===Example=== | ===Example=== | ||
− | {{example}} | + | {{example |
+ | |code= | ||
+ | #include <type_traits> | ||
+ | |||
+ | static_assert( | ||
+ | std::is_same< | ||
+ | std::bool_constant<false>, | ||
+ | typename std::negation<std::bool_constant<true>>::type>::value, | ||
+ | ""); | ||
+ | static_assert( | ||
+ | std::is_same< | ||
+ | std::bool_constant<true>, | ||
+ | typename std::negation<std::bool_constant<false>>::type>::value, | ||
+ | ""); | ||
+ | |||
+ | static_assert(std::negation_v<std::bool_constant<true>> == false); | ||
+ | static_assert(std::negation_v<std::bool_constant<false>> == true); | ||
+ | |||
+ | int main() {} | ||
+ | }} | ||
===See also=== | ===See also=== | ||
{{dsc begin}} | {{dsc begin}} | ||
− | {{dsc inc | cpp/types/dsc conjunction}} | + | {{dsc inc|cpp/types/dsc conjunction}} |
− | {{dsc inc | cpp/types/dsc disjunction}} | + | {{dsc inc|cpp/types/dsc disjunction}} |
+ | {{dsc inc|cpp/types/dsc integral_constant}} | ||
{{dsc end}} | {{dsc end}} | ||
− | + | {{langlinks|de|es|fr|it|ja|pt|ru|zh}} | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + |
Latest revision as of 12:18, 24 September 2024
Defined in header <type_traits>
|
||
template< class B > struct negation; |
(since C++17) | |
Forms the logical negation of the type trait B.
The type std::negation<B> is a UnaryTypeTrait with a base characteristic of std::bool_constant<!bool(B::value)>.
If the program adds specializations for std::negation
or std::negation_v
, the behavior is undefined.
Contents |
[edit] Template parameters
B | - | any type such that the expression bool(B::value) is a valid constant expression |
[edit] Helper variable template
template< class B > constexpr bool negation_v = negation<B>::value; |
(since C++17) | |
Inherited from std::integral_constant
Member constants
value [static] |
true if B has a member ::value that is false when explicitly converted to bool, false otherwise (public static member constant) |
Member functions
operator bool |
converts the object to bool, returns value (public member function) |
operator() (C++14) |
returns value (public member function) |
Member types
Type | Definition |
value_type
|
bool |
type
|
std::integral_constant<bool, value> |
[edit] Possible implementation
template<class B> struct negation : std::bool_constant<!bool(B::value)> { }; |
[edit] Notes
Feature-test macro | Value | Std | Feature |
---|---|---|---|
__cpp_lib_logical_traits |
201510L | (C++17) | Logical operator type traits |
[edit] Example
Run this code
#include <type_traits> static_assert( std::is_same< std::bool_constant<false>, typename std::negation<std::bool_constant<true>>::type>::value, ""); static_assert( std::is_same< std::bool_constant<true>, typename std::negation<std::bool_constant<false>>::type>::value, ""); static_assert(std::negation_v<std::bool_constant<true>> == false); static_assert(std::negation_v<std::bool_constant<false>> == true); int main() {}
[edit] See also
(C++17) |
variadic logical AND metafunction (class template) |
(C++17) |
variadic logical OR metafunction (class template) |
(C++11)(C++17) |
compile-time constant of specified type with specified value (class template) |