std::numeric_limits<T>::has_denorm_loss

来自cppreference.com
 
 
 
 
 
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 的值对于所有将在创建非正规数时的精度的损失检测为非正规化损失而非不准确结果(见后述)的浮点数类型 T 都是 true

标准特化

Tstd::numeric_limits<T>::has_denorm_loss 的值
/* 未特化 */false
boolfalse
charfalse
signed charfalse
unsigned charfalse
wchar_tfalse
char8_t (C++20 起)false
char16_t (C++11 起)false
char32_t (C++11 起)false
shortfalse
unsigned shortfalse
intfalse
unsigned intfalse
longfalse
unsigned longfalse
long long (C++11 起)false
unsigned long long (C++11 起)false
float由实现定义
double由实现定义
long double由实现定义

注解

遵从标准的非正规数的 IEEE 754 浮点数实现要求在出现关联到创建这种数的精度损失时检测它,而且可以以两种不同的方式进行:

  1. 非正规化损失:产生的结果与在假定指数范围无界的情况下计算出的结果不同。
  2. 不准确结果:产生的结果与在假定指数范围和精度均无界的情况下计算出的结果不同。

不存在非正规化损失机制的实现(精度损失在舍入后检测为不准确结果),而此选项在 IEEE 标准 754 的 2008 修订版被移除。

libstdc++、libc++、libCstd 及 stlport4 为所有浮点数类型定义此常量为 false。Microsoft Visual Studio 为所有浮点数类型定义它为 true

与任何浮点数计算一样,精度损失可能会引发 FE_INEXACT

示例

参阅

鉴别检测舍入前是否非正规的浮点数类型
(公开静态成员常量)
[静态]
识别浮点数类型所用的非正规风格
(公开静态成员常量)