Namespaces
Variants
Views
Actions

std::numeric_limits<T>::is_exact

From cppreference.com
 
 
Utilities library
General utilities
Date and time
Function objects
Formatting library (C++20)
(C++11)
Relational operators (deprecated in C++20)
Integer comparison functions
(C++20)
Swap and type operations
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Common vocabulary types
(C++11)
(C++17)
(C++17)
(C++17)
(C++17)

Elementary string conversions
(C++17)
(C++17)
 
Type support
Basic types
Fundamental types
Fixed width integer types (C++11)
Numeric limits
C numeric limits interface
Runtime type information
Type traits
Type categories
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
Type properties
(C++11)
(C++11)
(C++14)
(C++11)
(C++11)(until C++20)
(C++11)(deprecated in C++20)
(C++11)
Type trait constants
Metafunctions
(C++17)
Constant evaluation context
Supported operations
Relationships and property queries
Type modifications
(C++11)(C++11)(C++11)
Type transformations
(C++11)
(C++11)
(C++17)
(C++11)(until C++20)(C++17)
 
 
static const bool is_exact;
(until C++11)
static constexpr bool is_exact;
(since C++11)

The value of std::numeric_limits<T>::is_exact is true for all arithmetic types T that use exact representation.

[edit] Standard specializations

T value of std::numeric_limits<T>::is_exact
/* non-specialized */ false
bool true
char true
signed char true
unsigned char true
wchar_t true
char8_t (C++20) true
char16_t (C++11) true
char32_t (C++11) true
short true
unsigned short true
int true
unsigned int true
long true
unsigned long true
long long (C++11) true
unsigned long long (C++11) true
float false
double false
long double false

[edit] Notes

While all fundamental types T for which std::numeric_limits<T>::is_exact==true are integer types, a library may define exact types that aren't integers, e.g. a rational arithmetics type representing fractions.

[edit] See also

[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]