std::numeric_limits<T>::min
来自cppreference.com
< cpp | types | numeric limits
在标头 <limits> 定义
|
||
static T min() throw(); |
(C++11 前) | |
static constexpr T min() noexcept; |
(C++11 起) | |
返回数值类型 T
可表示的最小有限值。
对于有非正规化的浮点类型,min()
返回最小的正正规值。注意此行为可能是非预期的,特别是在与 min()
对整数类型的行为比较时。需要找到没有比它更小的值的值可以使用 lowest()
(C++11 起)。
min()
只对有界类型和无界无符号类型意义,即表示负值的无限集的类型无有意义的最小值。
返回值
T
|
std::numeric_limits<T>::min() |
/* 未特化 */ | T() |
bool | false |
char | CHAR_MIN |
signed char | SCHAR_MIN |
unsigned char | 0 |
wchar_t | WCHAR_MIN |
char8_t (C++20 起) | 0 |
char16_t (C++11 起) | 0 |
char32_t (C++11 起) | 0 |
short | SHRT_MIN |
unsigned short | 0 |
int | INT_MIN |
unsigned int | 0 |
long | LONG_MIN |
unsigned long | 0 |
long long (C++11 起) | LLONG_MIN |
unsigned long long (C++11 起) | 0 |
float | FLT_MIN |
double | DBL_MIN |
long double | LDBL_MIN |
示例
演示以 typedef 类型使用,及整数和浮点类型间结果符号的差异:
运行此代码
#include <cstddef> #include <iomanip> #include <iostream> #include <limits> template <typename T> void print_one(std::string_view type_name) { constexpr T min = std::numeric_limits<T>::min(); std::cout << std::dec << std::defaultfloat << std::setw(14) << type_name << " (" << std::setw(2) << sizeof(T) << " 字节): " << min; if constexpr (min != 0) std::cout << " 或 " << std::showbase << std::hex << std::hexfloat << min; std::cout << '\n'; } #define SHOW(T) print_one<T>(#T) int main() { SHOW(bool); SHOW(short); SHOW(unsigned short); SHOW(signed); SHOW(unsigned); SHOW(std::ptrdiff_t); SHOW(std::size_t); SHOW(float); SHOW(double); SHOW(long double); }
可能的输出:
bool ( 1 字节): 0 short ( 2 字节): -32768 或 0x8000 unsigned short ( 2 字节): 0 signed ( 4 字节): -2147483648 或 0x80000000 unsigned ( 4 字节): 0 std::ptrdiff_t ( 8 字节): -9223372036854775808 或 0x8000000000000000 std::size_t ( 8 字节): 0 float ( 4 字节): 1.17549e-38 或 0x1p-126 double ( 8 字节): 2.22507e-308 或 0x1p-1022 long double (16 字节): 3.3621e-4932 或 0x8p-16385
参阅
[静态] (C++11) |
返回给定类型的最低有限值 (公开静态成员函数) |
[静态] |
返回给定浮点类型的最小正非正规值 (公开静态成员函数) |
[静态] |
返回给定类型的最大有限值 (公开静态成员函数) |