|
| |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Basic types | |||||||||||||||||||||
| Fixed width integer types(C++11) | |||||||||||||||||||||
| Fixed width floating-point types(C++23) | |||||||||||||||||||||
| |||||||||||||||||||||
| Numeric limits | |||||||||||||||||||||
| C numeric limits interface | |||||||||||||||||||||
| Runtime type information | |||||||||||||||||||||
| |||||||||||||||||||||
| Static constants | ||||
numeric_limits::is_exact | ||||
(C++11) | ||||
| Static member functions | ||||
(C++11) | ||||
| Helper types | ||||
staticconstbool is_exact; | (until C++11) | |
staticconstexprbool is_exact; | (since C++11) | |
The value ofstd::numeric_limits<T>::is_exact istrue for all arithmetic typesT that use exact representation.
T | value ofstd::numeric_limits<T>::is_exact |
| /* non-specialized */ | false |
| bool | true |
| char | true |
| signedchar | true |
| unsignedchar | true |
| wchar_t | true |
| char8_t(since C++20) | true |
| char16_t(since C++11) | true |
| char32_t(since C++11) | true |
| short | true |
| unsignedshort | true |
| int | true |
| unsignedint | true |
| long | true |
| unsignedlong | true |
| longlong(since C++11) | true |
| unsignedlonglong(since C++11) | true |
| float | false |
| double | false |
| longdouble | false |
While all fundamental typesT for whichstd::numeric_limits<T>::is_exact==true are integer types, a library may define exact types that are not integers, e.g. a rational arithmetic type representing fractions.
[static] | identifies integer types (public static member constant)[edit] |
[static] | identifies signed types (public static member constant)[edit] |
[static] | identifies types that represent a finite set of values (public static member constant)[edit] |