How can I get the minimum and maximum exponent for 32- and 64-bit real numbers? I am doing some work to avoid underflows and overflows and would need to know those numbers.
The function range() returns the range of exponents. The intrinsic function huge() returns the maximum allowable number for a given numeric kind. From that you can see the exponent too by employing a logarithm. See also selected_real_kind().
The base for gfortran and other normal compilers is 2, but you can test it using radix(). They may be some base 10 kinds in the future.
In the same manual I linked you will find other useful intrinsics like tiny(), precision(), epsilon(), spacing()
, you can follow the links in "See also:".