Namespaces
Variants

std::numeric_limits<T>:: has_denorm_loss

From cppreference.net
Utilities library
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 реализации чисел с плавающей запятой для субнормальных чисел обязаны обнаруживать потерю точности, связанную с созданием такого числа, если она происходит, и могут делать это одним из двух различных способов:

  1. Потеря денормализации: полученный результат отличается от того, что был бы вычислен при неограниченном диапазоне экспоненты.
  2. Неточный результат: полученный результат отличается от того, что был бы вычислен при неограниченных диапазоне экспоненты и точности.

Реализация механизма потери денормализации отсутствует (потеря точности обнаруживается после округления, как неточный результат), и эта опция была удалена в редакции IEEE Std 754 2008 года.

libstdc++, libc++, libCstd и stlport4 определяют эту константу как false для всех типов с плавающей точкой. Microsoft Visual Studio определяет её как true для всех типов с плавающей точкой.

Как и при любых вычислениях с плавающей запятой, потеря точности может вызвать FE_INEXACT .

Пример

Смотрите также

идентифицирует типы с плавающей точкой, которые обнаруживают малость до округления
(публичная статическая константа-член)
[static]
идентифицирует стиль денормализации, используемый типом с плавающей точкой
(публичная статическая константа-член)