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>::digits10
std::numeric_limits<T>::digits10
| static const int digits10; |
(C++11 å) | |
| static constexpr int digits10 |
(C++11 èµ·) | |
std::numeric_limits<T>::digits10 ç弿¯ç±»å T è½æ æ´æ¹å°è¡¨ç¤ºçåº 10 使°ï¼å³ä»»ä½æ¥æè¿ä¹å¤åè¿å¶æææ°åçæ°è½è½¬æ¢æ T çå¼å¹¶è½¬æ¢ååè¿å¶å½¢å¼ï¼èä¸å èå
¥æä¸æº¢èæ´æ¹ã对äºåº radix ç±»åï¼å®æ¯ digits ï¼å¯¹äºæµ®ç¹ç±»åæ¯ digits-1 ï¼çå¼ä¹ log
10(radix) å¹¶åä¸åæ´ã
æ åç¹å
| Â | |
T
|
std::numeric_limits<T>::digits10 çå¼ |
| /* non-specialized */ | â0â |
| bool | â0â |
| char | std::numeric_limits<char>::digits * std::log10(2) |
| signed char | std::numeric_limits<signed char>::digits * std::log10(2) |
| unsigned char | std::numeric_limits<unsigned char>::digits * std::log10(2) |
| wchar_t | std::numeric_limits<wchar_t>::digits * std::log10(2) |
| char8_t | std::numeric_limits<char8_t>::digits * std::log10(2) |
| char16_t | std::numeric_limits<char16_t>::digits * std::log10(2) |
| char32_t | std::numeric_limits<char32_t>::digits * std::log10(2) |
| short | std::numeric_limits<short>::digits * std::log10(2) |
| unsigned short | std::numeric_limits<unsigned short>::digits * std::log10(2) |
| int | std::numeric_limits<int>::digits * std::log10(2) |
| unsigned int | std::numeric_limits<unsigned int>::digits * std::log10(2) |
| long | std::numeric_limits<long>::digits * std::log10(2) |
| unsigned long | std::numeric_limits<unsigned long>::digits * std::log10(2) |
| long long | std::numeric_limits<long long>::digits * std::log10(2) |
| unsigned long long | std::numeric_limits<unsigned long long>::digits * std::log10(2) |
| float | FLT_DIG /* IEEE float 为 6 */ |
| double | DBL_DIG /* IEEE double 为 15 */ |
| long double | LDBL_DIG /* 80 ä½ Intel long double 为 18 */ |
示ä¾
8 ä½äºè¿å¶ç±»åè½å确表示任ä½äºä½åè¿å¶æ°ï¼ä½ä¸è½è¡¨ç¤º 3 ä½åè¿å¶æ° 256..999 ã digits10 对 8 ä½ç±»åç弿¯ 2 ï¼ 8 * std::log10(2) 为 2.41 ï¼
æ å 32 ä½ IEEE 754 æµ®ç¹ç±»åæ¥æ 24 ä½å°æ°é¨åï¼ååº 23 ä½ï¼éå«ä¸ä½ï¼ï¼è¿å¯ä»¥å»ºè®®å®è½è¡¨ç¤º 7 ä½åè¿å¶æ°åï¼ 24 * std::log10(2) 为 7.22 ï¼ï¼ä½ç¸å¯¹è¯¯å·®ä¸ç»ä¸ï¼ä¸ä¸äºæ 7 ä½åè¿å¶æ°çæµ®ç¹å¼ä¸è½å¨è½¬æ¢å° 32 使µ®ç¹å转æ¢åæ¥åçåï¼æå°çæ£æ°ä¾åæ¯ 8.589973e9 ï¼å®å¨æ¥åèå
¥ååæ 8.589974e9 ãè¿äºè¯¯å·®å¨è¡¨ç¤ºä¸ä¸è½è¶
è¿ä¸ä½ï¼è digits10 æ (24-1)*std::log10(2) 计ç®ï¼å³ 6.92 ãåä¸åæ´ç»æå¯¼è´å¼ 6 ã
类似å°ï¼16 å符串 9007199254740993 卿æ¬->double->ææ¬åç¯ä¸ä¸ä¿æï¼å®å为 9007199254740992 ï¼ 64 ä½ IEEE 754 double ç±»åä» ä¿è¯ 15 ä½çèå ¥åç¯ã
åé
| [éæ] |
ç»å®ç±»åç表示æç¨çåºææ´æ°åº (å ¬å¼éææå常é) |
| [éæ] |
è½æ æ´æ¹å°è¡¨ç¤ºç radix 使° (å ¬å¼éææå常é) |
| [éæ] |
åºçè¯¥æ°æ¬¡å¹æ¯åæ³æ£è§æµ®ç¹å¼çæå°è´æ°å ä¸ (å ¬å¼éææå常é) |
| [éæ] |
åºçè¯¥æ°æ¬¡å¹æ¯åæ³æéæµ®ç¹å¼çæå¤§æ´æ°å ä¸ (å ¬å¼éææå常é) |