std::numeric_limits<T>:: has_denorm_loss
|
static
const
bool
has_denorm_loss
;
|
(до C++11) | |
|
static
constexpr
bool
has_denorm_loss
;
|
(начиная с C++11)
(устарело в C++23) |
|
Значение
std::
numeric_limits
<
T
>
::
has_denorm_loss
равно
true
для всех типов с плавающей точкой
T
, которые обнаруживают потерю точности при создании субнормального числа как потерю денормализации, а не как неточный результат (см. ниже).
Содержание |
Стандартные специализации
T
|
значение std:: numeric_limits < T > :: has_denorm_loss |
| /* non-specialized */ | false |
| bool | false |
| char | false |
| signed char | false |
| unsigned char | false |
| wchar_t | false |
| char8_t (начиная с C++20) | false |
| char16_t (начиная с C++11) | false |
| char32_t (начиная с C++11) | false |
| short | false |
| unsigned short | false |
| int | false |
| unsigned int | false |
| long | false |
| unsigned long | false |
| long long (начиная с C++11) | false |
| unsigned long long (начиная с C++11) | false |
| float | определяется реализацией |
| double | определяется реализацией |
| long double | определяется реализацией |
Примечания
Соответствующие стандарту IEEE 754 реализации чисел с плавающей запятой для субнормальных чисел обязаны обнаруживать потерю точности, связанную с созданием такого числа, если она происходит, и могут делать это одним из двух различных способов:
- Потеря денормализации: полученный результат отличается от того, что был бы вычислен при неограниченном диапазоне экспоненты.
- Неточный результат: полученный результат отличается от того, что был бы вычислен при неограниченных диапазоне экспоненты и точности.
Реализация механизма потери денормализации отсутствует (потеря точности обнаруживается после округления, как неточный результат), и эта опция была удалена в редакции IEEE Std 754 2008 года.
libstdc++, libc++, libCstd и stlport4 определяют эту константу как false для всех типов с плавающей точкой. Microsoft Visual Studio определяет её как true для всех типов с плавающей точкой.
Как и при любых вычислениях с плавающей запятой, потеря точности может вызвать FE_INEXACT .
Пример
|
Этот раздел не завершён
Причина: отсутствует пример |
Смотрите также
|
[static]
|
идентифицирует типы с плавающей точкой, которые обнаруживают малость до округления
(публичная статическая константа-член) |
|
[static]
|
идентифицирует стиль денормализации, используемый типом с плавающей точкой
(публичная статическая константа-член) |