C++ åèæå
- C++11
- C++14
- C++17
- C++20
- C++ ç¼è¯å¨æ¯ææ åµè¡¨
- ç¬ç«ä¸å®¿ä¸»å®ç°
- C++ è¯è¨
- C++ å ³é®è¯
- é¢å¤çå¨
- C++ æ ååºå¤´æä»¶
- å ·åè¦æ±
- åè½ç¹æ§æµè¯ (C++20)
- å·¥å ·åº
- ç±»åæ¯æï¼åºæ¬ç±»åãRTTIãç±»åç¹æ§ï¼
- std::numeric_limits
- std::numeric_limits<T>::is_integer
- std::numeric_limits<T>::is_exact
- std::numeric_limits<T>::is_specialized
- std::numeric_limits<T>::is_signed
- std::numeric_limits<T>::has_infinity
- std::numeric_limits<T>::has_quiet_NaN
- std::numeric_limits<T>::has_signaling_NaN
- std::numeric_limits<T>::has_denorm
- std::numeric_limits<T>::has_denorm_loss
- std::numeric_limits<T>::round_style
- std::numeric_limits<T>::is_iec559
- std::numeric_limits<T>::is_bounded
- std::numeric_limits<T>::is_modulo
- std::numeric_limits<T>::digits
- std::numeric_limits<T>::digits10
- std::numeric_limits<T>::max_digits10
- std::numeric_limits<T>::radix
- std::numeric_limits<T>::min_exponent
- std::numeric_limits<T>::min_exponent10
- std::numeric_limits<T>::max_exponent10
- std::numeric_limits<T>::max_exponent10
- std::numeric_limits<T>::traps
- std::numeric_limits<T>::tinyness_before
- std::numeric_limits<T>::min
- std::numeric_limits<T>::lowest
- std::numeric_limits<T>::max
- std::numeric_limits<T>::epsilon
- 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::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::numeric_limits > std::numeric_limits<T>::is_modulo
std::numeric_limits<T>::is_modulo
| static const bool is_modulo; |
(C++11 å) | |
| static constexpr bool is_modulo; |
(C++11 èµ·) | |
std::numeric_limits<T>::is_modulo 对ææå¯è½ (C++11 å)ä»¥æ¨¡ç®æ¯å¤ç溢åºçç®æ¯ç±»å T 为 true ãæ¨¡ç®æ¯å³è¥æ¤ç±»åçå æ³ãåæ³ã乿³æé¤æ³ç»æä¼è½å¨èå´ [min(), max()] å¤ï¼åè¿ç§è¿ç®è¿åçç»æä¸ææå¼ç¸å·® max()-min()+1 çæ´æ°åã
|
|
(C++11 èµ·) |
æ åç¹å
| Â | |
T
|
std::numeric_limits<T>::is_modulo çå¼ |
| /* non-specialized */ | false |
| bool | false |
| char | å®ç°å®ä¹ |
| signed char | å®ç°å®ä¹ |
| unsigned char | true |
| wchar_t | å®ç°å®ä¹ |
| char8_t | true |
| char16_t | true |
| char32_t | true |
| short | å®ç°å®ä¹ |
| unsigned short | true |
| int | å®ç°å®ä¹ |
| unsigned int | true |
| long | å®ç°å®ä¹ |
| unsigned long | true |
| long long | å®ç°å®ä¹ |
| unsigned long long | true |
| float | false |
| double | false |
| long double | false |
注æ
尽管 C++11 æ åä»ç¶è¯´âå¨å¤§å¤æ°æºå¨ä¸ï¼è¿å¯¹äºæç¬¦å·æ´æ°ä¸º true âï¼è¿æ¯ç¼ºé·èä¸å·²è¢«æ´æ£ãåç¡®æªè¾ä» C++03 å° C++11 çæ´æ¹ä½¿å¾ true å¼ä¸åä¸æç¬¦å·æ´æ°æº¢åºä¸çæªå®ä¹è¡ä¸ºå
¼å®¹ãå æ¤ï¼ä¾èµäºæç¬¦å·æº¢åºä¸ºæªå®ä¹ï¼ä¸ºäºä¼åæºä¼ï¼çå®ç°ç°å¨å¯¹æç¬¦å·æ´æ°è®¾ç½® is_modulo 为 false ãè§ç¤ºä¾ GCC PR 22200 ã
示ä¾
æ¼ç¤ºæ¨¡ç±»åçè¡ä¸º
#include <iostream> #include <type_traits> #include <limits>  template<class T> typename std::enable_if<std::numeric_limits<T>::is_modulo>::type check_overflow() { std::cout << "\nmax value is " << std::numeric_limits<T>::max() << '\n' << "min value is " << std::numeric_limits<T>::min() << '\n' << "max value + 1 is " << std::numeric_limits<T>::max()+1 << '\n'; }  int main() { check_overflow<int>(); check_overflow<unsigned long>(); // check_overflow<float>(); // ç¼è¯æ¶é误ï¼é模类å }
å¯è½çè¾åºï¼
max value is 2147483647 min value is -2147483648 max value + 1 is -2147483648 Â max value is 18446744073709551615 min value is 0 max value + 1 is 0
ç¼ºé·æ¥å
ä¸åæ´æ¹è¡ä¸ºçç¼ºé·æ¥å追溯å°åºç¨äºä»¥ååºçç C++ æ åã
| DR | åºç¨äº | åºçæ¶çè¡ä¸º | æ£ç¡®è¡ä¸º |
|---|---|---|---|
| LWG 2422 | C++11 | æ¾å¨å¤§å¤æ°æºå¨ä¸è¦æ± is_modulo 对æç¬¦å·æ´æ°ç±»å为 true
|
对æç¬¦å·æ´æ°ç±»åè¦æ±ä¸º false ï¼ é¤éå®ä¹æç¬¦å·æ´æ°æº¢åºä¸ºåç» |
åé
| [éæ] |
é´å«æ´æ°ç±»å (å ¬å¼éææå常é) |
| [éæ] |
é´å« IEC 559/IEEE 754 æµ®ç¹ç±»å (å ¬å¼éææå常é) |
| [éæ] |
é´å«å确表示çç±»å (å ¬å¼éææå常é) |