參考:https://www.cnblogs.com/zztt/p/3417323.html
總結
- Integer的最大數: Integer.MAX_VALUE (Long同理)
- Integer的最小數:Integer.MIN_VALUE (Long同理)
- Double的最大數:Double.MAX_VALUE (Float同理)
- Double的最小數:-Double.MAX_VALUE (Float同理)
詳細解釋
好吧, 吐嘈一下:
前幾天寫代碼時發現 Double 有幾個靜態成員變量, 如 MAX_VALUE
, MIN_VALUE
等, 當時就自己"故名思意"了, 分別當成了 double 能表示的最大, 最小值來用了.
幾天調試程序時發現了離奇的錯誤, 找了很久才找到錯誤, 見下例:
double temp = Double.MIN_VALUE; if (0<temp){ return true; }else { return false; }
你認為返回值是true? 還是 false?
實際運行返回的是逆天的 true !!!
無語, 查文檔吧,
static double |
MAX_VALUE
A constant holding the largest positive finite value of type
double , (2-2
-52)·2
1023.
|
static double |
MIN_VALUE
A constant holding the smallest positive nonzero value of type
double , 2
-1074.
|
文檔寫着, MIN_VALUE 是表示一個double類型最小的整數,但非零的常量, 具體值是 2-1074. 也就是說就算它無限接近於0, 但也確實比 0 大. 所以返回true.
但是, 親, 你直接取常量名 MIN_POSITIVE_VALUE 就好了啊, 就不會讓大家誤解了.
同理, 再看下 MAX_VALUE 是最大的"正無窮"常量.
故事這里還沒有結束,下面代碼是返回 true 還是 false 呢?
int temp = Integer.MIN_VALUE; if (0<temp){ return true; }else { return false; }
如果這次還選 true,那就又錯了,返回的是 false, 好吧,再查文檔:
static int |
MAX_VALUE
A constant holding the maximum value an
int can have, 2
31-1.
|
static int |
MIN_VALUE
A constant holding the minimum value an
int can have, -2
31.
|
這回又變回真正的 int 最小負值了, 這前后也不統一下,是要哪般啊。
這里要贊以下 .Net 童鞋, .Net與上面 Double.MIN_VALUE 有個類似的常量, 起名就叫 Double.Epsilon, 這個多明確的名字啊. 並且 .Net 也有 Double.MinValue, 人家表示的就是真正的負數的最小值.