std::numeric_limits<T>::min
From cppreference.com
| ヘッダ <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> // we want to print char types as an integer without leading Fs auto p(auto x) { return x; } auto p(char x) { return x & static_cast<unsigned char>(-1); } 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) << " bytes): " << +min; if constexpr (min != 0) std::cout << " or " << std::showbase << std::hex << std::hexfloat << p(min); std::cout << '\n'; } #define SHOW(T) print_one<T>(#T) int main() { SHOW(bool); SHOW(char); SHOW(unsigned char); 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 bytes): 0
char ( 1 bytes): -128 or 0x80
unsigned char ( 1 bytes): 0
short ( 2 bytes): -32768 or 0x8000
unsigned short ( 2 bytes): 0
signed ( 4 bytes): -2147483648 or 0x80000000
unsigned ( 4 bytes): 0
std::ptrdiff_t ( 8 bytes): -9223372036854775808 or 0x8000000000000000
std::size_t ( 8 bytes): 0
float ( 4 bytes): 1.17549e-38 or 0x1p-126
double ( 8 bytes): 2.22507e-308 or 0x1p-1022
long double (16 bytes): 3.3621e-4932 or 0x8p-16385[編集] 関連項目
| [static] (C++11) |
与えられた型の最小の有限値を返す。すなわち、符号付き型の場合は最も負の値、符号なし型の場合は 0 (public static member function) |
| [static] |
与えられた浮動小数点数型の最小の正の非正規化値を返す (public static member function) |
| [static] |
与えられた型の最大の有限値を返す (public static member function) |