Java是一種面向對象的編程語言,在進行數字運算時,需要學習浮點和整數運算的區別:
整數類型的運算是計算機中最基本的功能之一,它可以完成加減乘除等基本算術運算。與其它編程語言不同的是,Java中整數類型有四種,分別是byte(1個字節)、short(2個字節)、int(4個字節)和long(8個字節)。不同的整數類型可以存儲不同范圍的數值,但是在運算時,需要注意數據溢出的問題。
public static void main(String[] args) { int a = 2147483647; int b = a + 1; System.out.println(b); // -2147483648 }
在上面的代碼中,因為int類型的范圍是-2147483648 ~ 2147483647,當a+1超出了int類型的最大值2147483647時,將會發生數據溢出,得到的結果變成了-2147483648。
而浮點數的運算就比較復雜了,因為浮點數采用的是IEEE 754標準進行存儲和計算,此標準是一種二進制浮點數算術標準,常用于科學計算、圖像處理等領域。浮點數在計算機中以二進制的形式存儲,可以分為兩部分:尾數和指數。
在實際運算中,浮點數還需要注意以下概念:
- NaN(Not a Number):表示一個非數字的特殊值。
- Infinity(無窮大):表示一個超出了浮點數類型所能表示的最大范圍的數值。
- 精度誤差:因為浮點數的存儲方式,即使兩個數在數值上非常接近,但是在計算機中存儲的二進制數表示可能會有較大誤差。
public static void main(String[] args) { double a = 1.0 / 3; System.out.println(a * 3 == 1); // false }
以上代碼證明了浮點數的精度問題,因為1/3在計算機中表示為0.33333333……,而0.33333333*3等于0.99999999,所以結果為false。
在Java中,浮點數有兩種類型:float(4個字節)和double(8個字節),其中double類型的精確度比float更高,一般情況下建議使用double類型。
public static void main(String[] args) { double a = 0.1; double b = 0.2; System.out.println(a + b == 0.3); // false }
在上述代碼中,因為0.1和0.2無法用二進制數精確表示,有些位的精度會被丟失,所以a+b的結果也不等于0.3。