std::numeric_limits<T>:: min
From cppreference.net
<
cpp
|
types
|
numeric limits
|
헤더 파일에 정의됨
<limits>
|
||
|
static
T min
(
)
throw
(
)
;
|
(C++11 이전) | |
|
static
constexpr
T min
(
)
noexcept
;
|
(C++11 이후) | |
숫자 타입
T
로 표현 가능한 최소 유한 값을 반환합니다.
비정규화(denormalization)를 지원하는 부동 소수점 타입의 경우,
min()
는 최소 양수 정규화 값(normalized value)을 반환합니다.
특히 정수 타입의
min()
동작과 비교할 때 이 동작이 예상과 다를 수 있음에 유의하십시오
.
이보다 작은 값이 존재하지 않는 값을 찾으려면
lowest()
를 사용하십시오.
(C++11부터)
min()
는 bounded 타입과 unbounded unsigned 타입에 대해서만 의미가 있습니다.
반환값
T
|
std:: numeric_limits < T > :: min ( ) |
| /* non-specialized */ | 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
부호 없는 타입의 경우 0을 반환합니다.
(public static member function) |
|
[static]
|
주어진 부동소수점 타입의 가장 작은 양의 서브노멀 값을 반환합니다
(public static member function) |
|
[static]
|
주어진 타입의 가장 큰 유한값을 반환합니다
(public static member function) |