jav---int,float,long,double取值範圍,內存泄露

 1 public class TestOutOfBound { 
 2 public static void main(String[] args) { 
 3 
 4 System.out.println(Integer.MAX_VALUE-(-Integer.MAX_VALUE)); //內存溢出
 5 System.out.println(Integer.MAX_VALUE); //2的31次方-1,10個數位,正的20億左右,用在錢上面不必定夠 
 6 System.out.println(Integer.MIN_VALUE); //負的2的31次方 
 7 System.out.println(Long.MAX_VALUE); //2的64次方-1,19個數位,很大了,可放心用在錢上面 
 8 System.out.println(Long.MIN_VALUE); //負的2的64次方 
 9 System.out.println(Float.MAX_VALUE); //2的128次方-1,38個數位,比long多了一倍,這個主要用來作簡單數學精確運算使用 
10 System.out.println(Float.MIN_VALUE); //2的-149次方 
11 System.out.println(Double.MAX_VALUE); //2的1024次方-1,308個數位,是float數位的10倍,主要用來作複雜運算和天文運算 
12 System.out.println(Double.MIN_VALUE); //2的-1074次方 
13 
14 
15 
16 } 
17 }

 

 運行結果以下:spa

-2
2147483647
-2147483648
9223372036854775807
-9223372036854775808
3.4028235E38
1.4E-45
1.7976931348623157E308
4.9E-324code

 

   int和long都是很循規蹈矩的符合2的n次方的說法,int是32位,long是64位,惟有float和double像兩個淘氣的小孩子讓人會捉摸不透。float和double的表示形式與int和long是不同的,他們採用的是IEEE 754標準,這個標準能夠這樣理解:blog

(1)二者仍是32位的,和int同樣,最小值只是他們的精度,是正數,這是須要注意的。若是要取到他們負最大,在他們的最大值前加個符號就行了,如-Float.MAX_VALUE,就是float能表示的負的最大了。內存

(2)float從左到右,第一位是符號位,2-9位共8位表示整數位,2的8-1次方等於128,後面23位是表示小數的,因此最大值是2^128-1;數學

(3)double從左到右,第一位是符號位,2-12是共11位表示整數位,2的11-1次方等於1024。剩餘20位表示小數,因此最大值是2^1024-1.class

(4)如上面代碼,當正的最大減去負的正最大,就產生了內存泄露。溢出的結果是不對的。float

 

總結:int 和long,float和double的存儲要分別對待.要取到實實在在的最大最小值,只須要取到最大值就好了。總結

相關文章
相關標籤/搜索