C++标准模板(STL)- 类型支持 (数值极限,min,lowest,max)

数值极限

提供查询所有基础数值类型的性质的接口

定义于头文件 <limits>

template< class T > class numeric_limits;

numeric_limits 类模板提供查询各种算术类型属性的标准化方式(例如 int 类型的最大可能值是 std::numeric_limits<int>::max() )。
 

成员函数

返回给定类型的最小有限值

std::numeric_limits<T>::min

static T min() throw();

(C++11 前)

static constexpr T min() noexcept;

(C++11 起)

返回数值类型 T 可表示的最小有限值。

对于有非正规的浮点类型, min 返回最小正正规值。注意此行为可能是非预期的,特别是在与 min 对整数类型的行为比较时。为找到没有比它更小的值的值,请用 numeric_limits::lowest 。

min 仅对有界类型和无界无符号类型意义,即表示负值的无限集的类型无有意义的最小值。

返回值

Tstd::numeric_limits<T>::min()
/* non-specialized */T()
boolfalse
charCHAR_MIN
signed charSCHAR_MIN
unsigned char​0​
wchar_tWCHAR_MIN
char8_t​0​
char16_t​0​
char32_t​0​
shortSHRT_MIN
unsigned short​0​
intINT_MIN
unsigned int​0​
longLONG_MIN
unsigned long​0​
long longLLONG_MIN
unsigned long long​0​
floatFLT_MIN
doubleDBL_MIN
long doubleLDBL_MIN

调用示例

#include <iostream>
#include <string>
#include <limits>
#include <cstdint>
#include <cfloat>

struct SName
{
};

//偏特化
struct SPartSpec
{
};

namespace std
{
template<>
struct numeric_limits<SPartSpec>
{
    static _GLIBCXX_USE_CONSTEXPR bool is_specialized   = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_signed        = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_integer       = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_exact         = true;
    static _GLIBCXX_USE_CONSTEXPR bool has_infinity     = true;
    static _GLIBCXX_USE_CONSTEXPR bool has_quiet_NaN    = true;
    static _GLIBCXX_USE_CONSTEXPR bool has_signaling_NaN = true;
    static _GLIBCXX_USE_CONSTEXPR float_denorm_style has_denorm     = denorm_present;
    static _GLIBCXX_USE_CONSTEXPR bool has_denorm_loss  = true;
    static _GLIBCXX_USE_CONSTEXPR float_round_style round_style     = round_toward_neg_infinity;
    static _GLIBCXX_USE_CONSTEXPR bool is_iec559        = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_bounded       = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_modulo        = true;
    static _GLIBCXX_USE_CONSTEXPR int  digits           = CHAR_BIT;
    static _GLIBCXX_USE_CONSTEXPR int  digits10         = CHAR_BIT;
    static _GLIBCXX_USE_CONSTEXPR int  max_digits10     = DECIMAL_DIG;
    static _GLIBCXX_USE_CONSTEXPR int  radix            = FLT_RADIX;
    static _GLIBCXX_USE_CONSTEXPR int  min_exponent     = FLT_MIN_EXP;
    static _GLIBCXX_USE_CONSTEXPR int  min_exponent10   = FLT_MIN_10_EXP;
    static _GLIBCXX_USE_CONSTEXPR int  max_exponent     = FLT_MAX_EXP;
    static _GLIBCXX_USE_CONSTEXPR int  max_exponent10   = FLT_MAX_EXP;
    static _GLIBCXX_USE_CONSTEXPR bool traps            = true;
    static _GLIBCXX_USE_CONSTEXPR bool tinyness_before  = true;

    static _GLIBCXX_CONSTEXPR int
    min() _GLIBCXX_USE_NOEXCEPT { return  CHAR_MIN ; }
};
}

int main()
{
    std::cout << std::boolalpha;
    std::cout << "std::numeric_limits<bool>::min():                 "
              << std::numeric_limits<bool>::min() << std::endl;
    std::cout << "std::numeric_limits<char>::min():                 "
              << std::numeric_limits<char>::min() << std::endl;
    std::cout << "std::numeric_limits<signed char>::min():          "
              << std::numeric_limits<signed char>::min() << std::endl;
    std::cout << "std::numeric_limits<unsigned char>::min():        "
              << std::numeric_limits<unsigned char>::min() << std::endl;
    std::cout << "std::numeric_limits<wchar_t>::min():              "
              << std::numeric_limits<wchar_t>::min() << std::endl;
    std::cout << "std::numeric_limits<char16_t>::min():             "
              << std::numeric_limits<char16_t>::min() << std::endl;
    std::cout << "std::numeric_limits<char32_t>::min():             "
              << std::numeric_limits<char32_t>::min() << std::endl;
    std::cout << "std::numeric_limits<short>::min():                "
              << std::numeric_limits<short>::min() << std::endl;
    std::cout << "std::numeric_limits<unsigned short>::min():       "
              << std::numeric_limits<unsigned short>::min() << std::endl;
    std::cout << "std::numeric_limits<int>::min():                  "
              << std::numeric_limits<int>::min() << std::endl;
    std::cout << "std::numeric_limits<unsigned int>::min():         "
              << std::numeric_limits<unsigned int>::min() << std::endl;
    std::cout << "std::numeric_limits<long>::min():                 "
              << std::numeric_limits<long>::min() << std::endl;
    std::cout << "std::numeric_limits<unsigned long>::min():        "
              << std::numeric_limits<unsigned long>::min() << std::endl;
    std::cout << "std::numeric_limits<long long>::min():            "
              << std::numeric_limits<long long>::min() << std::endl;
    std::cout << "std::numeric_limits<unsigned long long>::min():   "
              << std::numeric_limits<unsigned long long>::min() << std::endl;
    std::cout << "std::numeric_limits<float>::min():                "
              << std::numeric_limits<float>::min() << std::endl;
    std::cout << "std::numeric_limits<double>::min():               "
              << std::numeric_limits<double>::min() << std::endl;
    std::cout << "std::numeric_limits<long double>::min():          "
              << std::numeric_limits<long double>::min() << std::endl;
    std::cout << "std::numeric_limits<std::string>::min():          "
              << std::numeric_limits<std::string>::min() << std::endl;
    //必须偏特化
//    std::cout << "std::numeric_limits<SName>::min():                "
//              << std::numeric_limits<SName>::min() << std::endl;
    std::cout << "std::numeric_limits<SPartSpec>::min():            "
              << std::numeric_limits<SPartSpec>::min() << std::endl;
    return 0;
}

输出

 

返回给定类型的最低有限值

std::numeric_limits<T>::lowest

static constexpr T lowest() noexcept;

(C++11 起)

返回数值类型 T 可表示的最低有限值,即满足无其他有限值 y 符合 y < x 的有限值 x 。这对于浮点类型不同于 std::numeric_limits<T>::min() 。仅对有界类型有意义。 

返回值

Tstd::numeric_limits<T>::lowest()
/* non-specialized */T();
boolfalse
charCHAR_MIN
signed charSCHAR_MIN
unsigned char​0​
wchar_tWCHAR_MIN
char8_t​0​
char16_t​0​
char32_t​0​
shortSHRT_MIN
unsigned short​0​
intINT_MIN
unsigned int​0​
longLONG_MIN
unsigned long​0​
long longLLONG_MIN
unsigned long long​0​
float-FLT_MAX
double-DBL_MAX
long double-LDBL_MAX

注意

尽管对于基础 C++ 浮点类型非真,可存在满足 std::numeric_limits<T>::lowest() != -std::numeric_limits<T>::max() 的第三方浮点类型 T 。\

调用示例

#include <iostream>
#include <string>
#include <limits>
#include <cstdint>
#include <cfloat>

struct SName
{
};

//偏特化
struct SPartSpec
{
};

namespace std
{
template<>
struct numeric_limits<SPartSpec>
{
    static _GLIBCXX_USE_CONSTEXPR bool is_specialized   = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_signed        = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_integer       = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_exact         = true;
    static _GLIBCXX_USE_CONSTEXPR bool has_infinity     = true;
    static _GLIBCXX_USE_CONSTEXPR bool has_quiet_NaN    = true;
    static _GLIBCXX_USE_CONSTEXPR bool has_signaling_NaN = true;
    static _GLIBCXX_USE_CONSTEXPR float_denorm_style has_denorm     = denorm_present;
    static _GLIBCXX_USE_CONSTEXPR bool has_denorm_loss  = true;
    static _GLIBCXX_USE_CONSTEXPR float_round_style round_style     = round_toward_neg_infinity;
    static _GLIBCXX_USE_CONSTEXPR bool is_iec559        = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_bounded       = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_modulo        = true;
    static _GLIBCXX_USE_CONSTEXPR int  digits           = CHAR_BIT;
    static _GLIBCXX_USE_CONSTEXPR int  digits10         = CHAR_BIT;
    static _GLIBCXX_USE_CONSTEXPR int  max_digits10     = DECIMAL_DIG;
    static _GLIBCXX_USE_CONSTEXPR int  radix            = FLT_RADIX;
    static _GLIBCXX_USE_CONSTEXPR int  min_exponent     = FLT_MIN_EXP;
    static _GLIBCXX_USE_CONSTEXPR int  min_exponent10   = FLT_MIN_10_EXP;
    static _GLIBCXX_USE_CONSTEXPR int  max_exponent     = FLT_MAX_EXP;
    static _GLIBCXX_USE_CONSTEXPR int  max_exponent10   = FLT_MAX_EXP;
    static _GLIBCXX_USE_CONSTEXPR bool traps            = true;
    static _GLIBCXX_USE_CONSTEXPR bool tinyness_before  = true;

    static _GLIBCXX_CONSTEXPR int
    min() _GLIBCXX_USE_NOEXCEPT { return  CHAR_MIN ; }
    static _GLIBCXX_CONSTEXPR int
    lowest() _GLIBCXX_USE_NOEXCEPT { return  CHAR_MIN ; }
};
}

int main()
{
    std::cout << std::boolalpha;
    std::cout << "std::numeric_limits<bool>::lowest():                 "
              << std::numeric_limits<bool>::lowest() << std::endl;
    std::cout << "std::numeric_limits<char>::lowest():                 "
              << std::numeric_limits<char>::lowest() << std::endl;
    std::cout << "std::numeric_limits<signed char>::lowest():          "
              << std::numeric_limits<signed char>::lowest() << std::endl;
    std::cout << "std::numeric_limits<unsigned char>::lowest():        "
              << std::numeric_limits<unsigned char>::lowest() << std::endl;
    std::cout << "std::numeric_limits<wchar_t>::lowest():              "
              << std::numeric_limits<wchar_t>::lowest() << std::endl;
    std::cout << "std::numeric_limits<char16_t>::lowest():             "
              << std::numeric_limits<char16_t>::lowest() << std::endl;
    std::cout << "std::numeric_limits<char32_t>::lowest():             "
              << std::numeric_limits<char32_t>::lowest() << std::endl;
    std::cout << "std::numeric_limits<short>::lowest():                "
              << std::numeric_limits<short>::lowest() << std::endl;
    std::cout << "std::numeric_limits<unsigned short>::lowest():       "
              << std::numeric_limits<unsigned short>::lowest() << std::endl;
    std::cout << "std::numeric_limits<int>::lowest():                  "
              << std::numeric_limits<int>::lowest() << std::endl;
    std::cout << "std::numeric_limits<unsigned int>::lowest():         "
              << std::numeric_limits<unsigned int>::lowest() << std::endl;
    std::cout << "std::numeric_limits<long>::lowest():                 "
              << std::numeric_limits<long>::lowest() << std::endl;
    std::cout << "std::numeric_limits<unsigned long>::lowest():        "
              << std::numeric_limits<unsigned long>::lowest() << std::endl;
    std::cout << "std::numeric_limits<long long>::lowest():            "
              << std::numeric_limits<long long>::lowest() << std::endl;
    std::cout << "std::numeric_limits<unsigned long long>::lowest():   "
              << std::numeric_limits<unsigned long long>::lowest() << std::endl;
    std::cout << "std::numeric_limits<float>::lowest():                "
              << std::numeric_limits<float>::lowest() << std::endl;
    std::cout << "std::numeric_limits<double>::lowest():               "
              << std::numeric_limits<double>::lowest() << std::endl;
    std::cout << "std::numeric_limits<long double>::lowest():          "
              << std::numeric_limits<long double>::lowest() << std::endl;
    std::cout << "std::numeric_limits<std::string>::lowest():          "
              << std::numeric_limits<std::string>::lowest() << std::endl;
    //必须偏特化
//    std::cout << "std::numeric_limits<SName>::lowest():                "
//              << std::numeric_limits<SName>::lowest() << std::endl;
    std::cout << "std::numeric_limits<SPartSpec>::lowest():            "
              << std::numeric_limits<SPartSpec>::lowest() << std::endl;
    return 0;
}

 输出

返回给定类型的最大有限值

std::numeric_limits<T>::max

static T max() throw();

(C++11 前)

static constexpr T max() noexcept;

(C++11 起)

返回数值类型 T 所能表示的最大有限值。对所有有界类型有意义。

返回值

Tstd::numeric_limits<T>::max()
/* non-specialized */T()
booltrue
charCHAR_MAX
signed charSCHAR_MAX
unsigned charUCHAR_MAX
wchar_tWCHAR_MAX
char8_tUCHAR_MAX
char16_tUINT_LEAST16_MAX
char32_tUINT_LEAST32_MAX
shortSHRT_MAX
unsigned shortUSHRT_MAX
intINT_MAX
unsigned intUINT_MAX
longLONG_MAX
unsigned longULONG_MAX
long longLLONG_MAX
unsigned long longULLONG_MAX
floatFLT_MAX
doubleDBL_MAX
long doubleLDBL_MAX

调用示例

#include <iostream>
#include <string>
#include <limits>
#include <cstdint>
#include <cfloat>

struct SName
{
};

//偏特化
struct SPartSpec
{
};

namespace std
{
template<>
struct numeric_limits<SPartSpec>
{
    static _GLIBCXX_USE_CONSTEXPR bool is_specialized   = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_signed        = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_integer       = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_exact         = true;
    static _GLIBCXX_USE_CONSTEXPR bool has_infinity     = true;
    static _GLIBCXX_USE_CONSTEXPR bool has_quiet_NaN    = true;
    static _GLIBCXX_USE_CONSTEXPR bool has_signaling_NaN = true;
    static _GLIBCXX_USE_CONSTEXPR float_denorm_style has_denorm     = denorm_present;
    static _GLIBCXX_USE_CONSTEXPR bool has_denorm_loss  = true;
    static _GLIBCXX_USE_CONSTEXPR float_round_style round_style     = round_toward_neg_infinity;
    static _GLIBCXX_USE_CONSTEXPR bool is_iec559        = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_bounded       = true;
    static _GLIBCXX_USE_CONSTEXPR bool is_modulo        = true;
    static _GLIBCXX_USE_CONSTEXPR int  digits           = CHAR_BIT;
    static _GLIBCXX_USE_CONSTEXPR int  digits10         = CHAR_BIT;
    static _GLIBCXX_USE_CONSTEXPR int  max_digits10     = DECIMAL_DIG;
    static _GLIBCXX_USE_CONSTEXPR int  radix            = FLT_RADIX;
    static _GLIBCXX_USE_CONSTEXPR int  min_exponent     = FLT_MIN_EXP;
    static _GLIBCXX_USE_CONSTEXPR int  min_exponent10   = FLT_MIN_10_EXP;
    static _GLIBCXX_USE_CONSTEXPR int  max_exponent     = FLT_MAX_EXP;
    static _GLIBCXX_USE_CONSTEXPR int  max_exponent10   = FLT_MAX_EXP;
    static _GLIBCXX_USE_CONSTEXPR bool traps            = true;
    static _GLIBCXX_USE_CONSTEXPR bool tinyness_before  = true;

    static _GLIBCXX_CONSTEXPR int
    min() _GLIBCXX_USE_NOEXCEPT { return  CHAR_MIN ; }
    static _GLIBCXX_CONSTEXPR int
    lowest() _GLIBCXX_USE_NOEXCEPT { return  CHAR_MIN ; }
    static _GLIBCXX_CONSTEXPR int
    max() _GLIBCXX_USE_NOEXCEPT { return  CHAR_MAX ; }
};
}

int main()
{
    std::cout << std::boolalpha;
    std::cout << "std::numeric_limits<bool>::max():                 "
              << std::numeric_limits<bool>::max() << std::endl;
    std::cout << "std::numeric_limits<char>::max():                 "
              << std::numeric_limits<char>::max() << std::endl;
    std::cout << "std::numeric_limits<signed char>::max():          "
              << std::numeric_limits<signed char>::max() << std::endl;
    std::cout << "std::numeric_limits<unsigned char>::max():        "
              << std::numeric_limits<unsigned char>::max() << std::endl;
    std::cout << "std::numeric_limits<wchar_t>::max():              "
              << std::numeric_limits<wchar_t>::max() << std::endl;
    std::cout << "std::numeric_limits<char16_t>::max():             "
              << std::numeric_limits<char16_t>::max() << std::endl;
    std::cout << "std::numeric_limits<char32_t>::max():             "
              << std::numeric_limits<char32_t>::max() << std::endl;
    std::cout << "std::numeric_limits<short>::max():                "
              << std::numeric_limits<short>::max() << std::endl;
    std::cout << "std::numeric_limits<unsigned short>::max():       "
              << std::numeric_limits<unsigned short>::max() << std::endl;
    std::cout << "std::numeric_limits<int>::max():                  "
              << std::numeric_limits<int>::max() << std::endl;
    std::cout << "std::numeric_limits<unsigned int>::max():         "
              << std::numeric_limits<unsigned int>::max() << std::endl;
    std::cout << "std::numeric_limits<long>::max():                 "
              << std::numeric_limits<long>::max() << std::endl;
    std::cout << "std::numeric_limits<unsigned long>::max():        "
              << std::numeric_limits<unsigned long>::max() << std::endl;
    std::cout << "std::numeric_limits<long long>::max():            "
              << std::numeric_limits<long long>::max() << std::endl;
    std::cout << "std::numeric_limits<unsigned long long>::max():   "
              << std::numeric_limits<unsigned long long>::max() << std::endl;
    std::cout << "std::numeric_limits<float>::max():                "
              << std::numeric_limits<float>::max() << std::endl;
    std::cout << "std::numeric_limits<double>::max():               "
              << std::numeric_limits<double>::max() << std::endl;
    std::cout << "std::numeric_limits<long double>::max():          "
              << std::numeric_limits<long double>::max() << std::endl;
    std::cout << "std::numeric_limits<std::string>::max():          "
              << std::numeric_limits<std::string>::max() << std::endl;
    //必须偏特化
//    std::cout << "std::numeric_limits<SName>::max():                "
//              << std::numeric_limits<SName>::max() << std::endl;
    std::cout << "std::numeric_limits<SPartSpec>::max():            "
              << std::numeric_limits<SPartSpec>::max() << std::endl;
    return 0;
}

输出

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值