C++ åèæå
- C++11
- C++14
- C++17
- C++20
- C++ ç¼è¯å¨æ¯ææ åµè¡¨
- ç¬ç«ä¸å®¿ä¸»å®ç°
- C++ è¯è¨
- C++ å ³é®è¯
- é¢å¤çå¨
- C++ æ ååºå¤´æä»¶
- å ·åè¦æ±
- åè½ç¹æ§æµè¯ (C++20)
- å·¥å ·åº
- ç±»åæ¯æï¼åºæ¬ç±»åãRTTIãç±»åç¹æ§ï¼
- std::result_of, std::invoke_result
- std::integral_constant
- std::is_constant_evaluated
- std::max_align_t
- offsetof
- NULL
- std::bad_typeid
- std::bad_cast
- std::numeric_limits
- std::type_info
- std::ptrdiff_t
- std::byte
- std::conjunction
- std::disjunction
- std::negation
- std::is_swappable_with, std::is_swappable, std::is_nothrow_swappable_with, std::is_nothrow_swappable
- std::is_invocable, std::is_invocable_r, std::is_nothrow_invocable, std::is_nothrow_invocable_r
- std::is_aggregate
- std::has_unique_object_representations
- std::endian
- std::remove_cvref
- std::type_index
- C æ°å¼æéæ¥å£
- å®å®½æ´æ°ç±»å (C++11 èµ·)
- std::is_bounded_array
- std::is_unbounded_array
- std::size_t
- std::nullptr_t
- std::is_integral
- std::rank
- std::is_void
- std::is_null_pointer
- std::is_array
- std::is_pointer
- std::is_enum
- std::is_union
- std::is_class
- std::is_function
- std::is_object
- std::is_scalar
- std::is_compound
- std::is_floating_point
- std::is_fundamental
- std::is_arithmetic
- std::is_reference
- std::is_lvalue_reference
- std::is_rvalue_reference
- std::is_member_pointer
- std::is_member_object_pointer
- std::is_member_function_pointer
- std::is_const
- std::is_volatile
- std::is_empty
- std::is_polymorphic
- std::is_final
- std::is_abstract
- std::is_trivial
- std::is_trivially_copyable
- std::is_standard_layout
- std::is_literal_type
- std::is_pod
- std::is_signed
- std::is_unsigned
- std::is_constructible, std::is_trivially_constructible, std::is_nothrow_constructible
- std::is_default_constructible, std::is_trivially_default_constructible, std::is_nothrow_default_constructible
- std::is_copy_constructible, std::is_trivially_copy_constructible, std::is_nothrow_copy_constructible
- std::is_move_constructible, std::is_trivially_move_constructible, std::is_nothrow_move_constructible
- std::is_assignable, std::is_trivially_assignable, std::is_nothrow_assignable
- std::is_copy_assignable, std::is_trivially_copy_assignable, std::is_nothrow_copy_assignable
- std::is_move_assignable, std::is_trivially_move_assignable, std::is_nothrow_move_assignable
- std::is_destructible, std::is_trivially_destructible, std::is_nothrow_destructible
- std::has_virtual_destructor
- std::is_same
- std::is_base_of
- std::is_convertible, std::is_nothrow_convertible
- std::is_layout_compatible
- std::is_pointer_interconvertible_base_of
- std::is_pointer_interconvertible_with_class
- std::is_corresponding_member
- std::alignment_of
- std::extent
- std::remove_cv, std::remove_const, std::remove_volatile
- std::add_cv, std::add_const, std::add_volatile
- std::make_signed
- std::make_unsigned
- std::remove_reference
- std::add_lvalue_reference, std::add_rvalue_reference
- std::remove_pointer
- std::add_pointer
- std::remove_extent
- std::remove_all_extents
- std::aligned_storage
- std::aligned_union
- std::decay
- std::enable_if
- std::void_t
- std::conditional
- std::common_type
- std::common_reference
- std::underlying_type
- std::type_identity
- 注é
- æ¦å¿µåº (C++20)
- é误å¤ç
- 卿å å管ç
- æ¥æåæ¶é´å·¥å ·
- å符串åº
- 容å¨åº
- è¿ä»£å¨åº
- èå´åº (C++20)
- ç®æ³åº
- æ°å¼åº
- è¾å ¥/è¾åºåº
- æä»¶ç³»ç»åº
- æ¬å°ååº
- æ£å表达å¼åº
- ååæä½åº
- çº¿ç¨æ¯æåº
- å®éªæ§ C++ ç¹æ§
- æç¨çèµæº
- ç´¢å¼
- std 符å·ç´¢å¼
- åç¨æ¯æ (C++20)
- C++ å ³é®è¯
ä½ç½®ï¼é¦é¡µ > C++ åèæå >ç±»åæ¯æï¼åºæ¬ç±»åãRTTIãç±»åç¹æ§ï¼ > std::disjunction
std::disjunction
| å®ä¹äºå¤´æä»¶ <type_traits>
|
||
| template<class... B> struct disjunction; |
(1) | (C++17 èµ·) |
ç»æç±»åç¹æ§ B... çé»è¾æåï¼çæå°å¨ç¹æ§åºåä¸è¿è¡é»è¾æã
ç¹å std::disjunction<B1, ..., BN> æä¸ä¸ªå ¬å¼ä¸æ æ§ä¹çåºç±»ï¼å³
- è¥ sizeof...(B) == 0 ï¼å为 std::false_type ï¼å¦å
- è¥
B1, ..., BN䏿 bool(Bi::value) == true ï¼å为é¦ä¸ªBiï¼æè è¥æ è¿ç§ç±»åå为BNã
ä¸éè disjunction å operator= 以å¤çåºç±»æååï¼èå®ä»¬å¨ disjunction 䏿 æ§ä¹å°å¯ç¨ã
æåæ¯çè·¯çï¼è¥å卿¨¡æ¿ç±»ååæ° Bi 满足 bool(Bi::value) != falseï¼åå®ä¾å
disjunction<B1, ..., BN>::value ä¸è¦æ± j > i ç Bj::value çå®ä¾åã
æ·»å disjunction æ disjunction_v çç¹åçç¨åºè¡ä¸ºæªå®ä¹ã
模æ¿å½¢å
| B... | - | æ¯ä¸ªè¦å®ä¾å Bi::value çæ¨¡æ¿åæ° Bi å¿
é¡»å¯ç¨ä½åºç±»ï¼ä¸å®ä¹äºå¯è½¬æ¢å° bool çæå value
|
è¾ å©å鿍¡æ¿
| template<class... B> inline constexpr bool disjunction_v = disjunction<B...>::value; |
(C++17 èµ·) | |
å¯è½çå®ç°
template<class...> struct disjunction : std::false_type { }; template<class B1> struct disjunction<B1> : B1 { }; template<class B1, class... Bn> struct disjunction<B1, Bn...> : std::conditional_t<bool(B1::value), B1, disjunction<Bn...>> { }; |
注解
disjunction çç¹åä¸éè¦ç»§æ¿èª std::true_type æ std::false_type ï¼å®ç®åå°ç»§æ¿èªé¦ä¸ª B ï¼å
¶ ::value 卿¾å¼è½¬æ¢ä¸º bool å为 true ï¼æå¨å®ä»¬é½è½¬æ¢ä¸º false æ¶ç»§æ¿èªæåç B ãä¾å¦ï¼ std::disjunction<std::integral_constant<int, 2>, std::integral_constant<int, 4>>::value 为 2 ã
disjunction ççè·¯å®ä¾åå¼äºæå 表达å¼ï¼å¦ (... || Bs::value) çæå 表达å¼å®ä¾å Bs ä¸çæ¯ä¸ª B ï¼è std::disjunction_v<Bs...> 䏿¦è½ç¡®å®å¼å°±åæ¢å®ä¾åãè¿å¨ä¹åçç±»åå®ä¾åä»£ä»·é«æï¼æä»¥é误çç±»åå®ä¾åè½å¯¼è´ç¡¬é误æ¶ç¹å«æç¨ã
示ä¾
#include <type_traits> #include <string>  // æ£æ¥ Foo æ¯å¦è½ä» double æé ä¼å¯¼è´ç¡¬é误 struct Foo { template<class T> struct sfinae_unfriendly_check { static_assert(!std::is_same_v<T, double>); };  template<class T> Foo(T, sfinae_unfriendly_check<T> = {} ); };  template<class... Ts> struct first_constructible { template<class T, class...Args> struct is_constructible_x : std::is_constructible<T, Args...> { using type = T; }; struct fallback { static constexpr bool value = true; using type = void; // è¥æ¾ä¸å°å 容åè¿åçç±»å };  template<class... Args> using with = typename std::disjunction<is_constructible_x<Ts, Args...>..., fallback>::type; };  // OK ï¼ä¸å®ä¾å is_constructible<Foo, double> static_assert(std::is_same_v<first_constructible<std::string, int, Foo>::with<double>, int>);  static_assert(std::is_same_v<first_constructible<std::string, int>::with<>, std::string>); static_assert(std::is_same_v<first_constructible<std::string, int>::with<const char*>, std::string>); static_assert(std::is_same_v<first_constructible<std::string, int>::with<void*>, void>);  int main() { }
åé
| (C++17) |
é»è¾éå
彿° (类模æ¿) |
| (C++17) |
ååçé»è¾ä¸å
彿° (类模æ¿) |