C++笔记:std::numeric_limits

std::numeric_limits 是 C++ 标准库里一个 用来查询数值类型“性质”的模板类
简单说:

它提供某个数值类型的各种边界和特性信息(最大值、最小值、精度、是否有无穷等)。

#include <limits>
template<class T>
class std::numeric_limits;

通过 numeric_limits 模板的特化提供此信息。标准库为所有算术类型制定可用的特化:


template<> class numeric_limits<bool>;
   

template<> class numeric_limits<char>;
   

template<> class numeric_limits<signed char>;
   

template<> class numeric_limits<unsigned char>;
   

template<> class numeric_limits<wchar_t>;
   

template<> class numeric_limits<char8_t>;
  (C++20 起) 

template<> class numeric_limits<char16_t>;
  (C++11 起) 

template<> class numeric_limits<char32_t>;
  (C++11 起) 

template<> class numeric_limits<short>;
   

template<> class numeric_limits<unsigned short>;
   

template<> class numeric_limits<int>;
   

template<> class numeric_limits<unsigned int>;
   

template<> class numeric_limits<long>;
   

template<> class numeric_limits<unsigned long>;
   

template<> class numeric_limits<long long>;
  (C++11 起) 

template<> class numeric_limits<unsigned long long>;
  (C++11 起) 

template<> class numeric_limits<float>;
   

template<> class numeric_limits<double>;
   

template<> class numeric_limits<long double>; 

另外,对于每个存在特化的 cv 无限定类型的每个 cv 限定版本存在特化,等同于非限定的特化,例如提供 std::numeric_limits<const int>std::numeric_limits<volatile int>std::numeric_limits<const volatile int> ,且它们等价于 std::numeric_limits<int>

成员常量

成员类型含义
is_specializedbool是否为该类型提供了 numeric_limits 特化
is_signedbool是否是有符号类型
is_integerbool是否是整数类型
is_exactbool是否能精确表示(整数为 true,浮点为 false)
has_infinitybool是否支持 +∞
has_quiet_NaNbool是否支持 quiet NaN
has_signaling_NaNbool是否支持 signaling NaN
has_denorm_lossbool是否会检测 denorm 精度损失
is_iec559bool是否符合 IEEE 754
is_boundedbool是否有有限范围
is_modulobool是否按模运算处理溢出(如 unsigned)
trapsbool算术运算是否可能产生 trap
tinyness_beforebool是否在舍入前检测 tiny 值
成员类型含义
digitsint能无误表示的 radix 位数
digits10int能无误表示的 十进制位数
max_digits10int保证 round-trip 的十进制位数
radixint数值表示使用的 进制基数
min_exponentint最小正规指数(radix)
min_exponent10int最小正规指数(10)
max_exponentint最大指数(radix)
max_exponent10int最大指数(10)
成员类型含义
has_denormstd::float_denorm_style说明
denorm_absent没有 denormal
denorm_present支持 denormal
denorm_indeterminate实现未指定
round_stylestd::float_round_style说明
round_to_nearest最近值舍入(IEEE754默认)
round_toward_zero向0舍入
round_toward_infinity向 +∞
round_toward_neg_infinity向 -∞

成员函数

都返回T类型

成员函数含义
min

返回类型 T最小有限值

整数类型:返回最小值

浮点类型:返回 最小正正规数(smallest positive normalized value)

lowest返回 最小的有限值(最负的值)
max返回该类型 最大有限值
epsilon1下一个可表示浮点数之间的差
round_error

返回 最大舍入误差(maximum rounding error)

对 IEEE754 浮点来说通常:0.5

infinity返回 正无穷大

仅当:std::numeric_limits<T>::has_infinity == true

quiet_NaN

返回 quiet NaN(安静 NaN)

不会触发异常;运算会继续传播

signaling_NaN

返回 signaling NaN(发信 NaN)

用于 触发浮点异常;某些运算会产生 trap

但现实中:很多平台不会真正区分 sNaN

denorm_min返回 最小正非正规数(subnormal / denormal)

例如

#include <iostream>
#include<limits>
int main()
{
    std::cout<<std::numeric_limits<float>::infinity()<<std::endl;
    std::cout << std::numeric_limits<float>::quiet_NaN() << std::endl;
}
inf
nan

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值