Kiedy uruchomić ten kod:Dlaczego liczbaic_limits <T> :: min() nie zwraca najmniejszej wartości?
#include <limits>
#include <cstdio>
#define T double
int main()
{
static const T val = std::numeric_limits<T>::min();
printf("%g/2 = %g\n", val, val/2);
}
spodziewałbym się zobaczyć nieprzewidywalne rezultaty. Ale mam prawidłową odpowiedź:
(16:53) > clang++ test_division.cpp -o test_division
(16:54) > ./test_division
2.22507e-308/2 = 1.11254e-308
Jak to możliwe?
lektura http://en.cppreference.com/w/cpp/types/numeric_limits/min – chris
@crhis Dziękuję, to było oczywiste, ale ja nigdy się tego rozróżnienia między znormalizowane/nieznormalizowana .. Nauka na co dzień, myślę, innym przydatnym linkiem jest: http://en.cppreference.com/w/cpp/types/numeric_limits/denorm_min – Sheljohn