現在要是進行正常的程序開發,基本上程序語言里面提供的數據類型里面都能夠滿足開發人員的需求,而且在整個的基礎編程語言里面的double(保存范圍:4.9E-324 ~ 1.7976931348623157E308)數據類型可以保存的范圍是非常大的。
但是呢,現在某些的程序計算有可能要進行更大的數字計算操作,那么這種情況下就不可能采用常規的形式完成處理,所以按照傳統的編程語言模型來講,此時一般都會利用字符串實現大數字數據的保存。為了解決這樣的難題,設計專門提供了一個java.math的包,而在這個包里面提供有兩個程序類:BigInteger(大整數的操作類)、BigDecimal(大小數的操作類)。
BigInteger類的使用
如果夏哀嗯要使用BigInteger,那么就需要通過構造方法來進行BigInteger類對象的實例化,此類的構造方法定義如下:
public BigInteger(byte[] val)
在使用BigInteger的時候需要明確的傳入一個字符串,而這個字符串所包含的就是一個大數字信息,當獲取了BigInteger類的對象實例之后,就可以利用起本身提供的方法,進行數學運算。
范例:通過BigInteger類實現四則運算
import java.math.BigInteger;
public class Test {
public static void main(String[] args) {
BigInteger bigIntA = new BigInteger("84561894561364516451654354"); //大數字類
BigInteger bigIntB = new BigInteger("95476536532545312587654654"); //大數字類
System.out.println("加法計算:" + bigIntA.add(bigIntB));
System.out.println("減法計算:" + bigIntA.subtract(bigIntB));
System.out.println("乘法計算:" + bigIntA.multiply(bigIntB));
System.out.println("除法計算:" + bigIntA.divide(bigIntB));
//當前給定的兩個數字類對象是不可能進行整除處理的。所以可以采用余數的形式進行除法計算
BigInteger result [] = bigIntA.divideAndRemainder(bigIntB);
System.out.println("除法計算 -> " + "商: " + result[0] + " , 余:" + result[1]);
}
}
輸出結果:
加法計算:180038431093909829039309008
減法計算:-10914641971180796136000300
乘法計算:8073676815349364036305129638756291550362695127463516
除法計算:0
除法計算 -> 商: 0 , 余:84561894561364516451654354
所有的大數字類都可以完成普通計算的基本操作支持,但是如果想要執行更加繁瑣的大數字的計算操作,肯定要額外的使用第三方的程序組件包來完善程序功能。
BigDecimal類使用
BigDecimal類所描述的是一個小數,但是這個類所具備的功能比BigInteger豐富,尤其在構造方法的定義上。
從構造方法本身給出的定義來講,BigDecimal構造實際上功能會更加的豐富,它本身的處理方法與形式和BigInteger是非常類似的,下面使用BigDecimal類實現四則運算。
范例:
import java.math.BigDecimal;
import java.math.RoundingMode;
public class Test {
public static void main(String[] args) {
BigDecimal bigDecimalA = new BigDecimal("84561894561.364516451654354"); //大數字類
BigDecimal bigDecimalB = new BigDecimal("9547653653.2545312587654654"); //大數字類
System.out.println("加法計算:" + bigDecimalA.add(bigDecimalB));
System.out.println("減法計算:" + bigDecimalA.subtract(bigDecimalB));
System.out.println("乘法計算:" + bigDecimalA.multiply(bigDecimalB));
System.out.println("除法計算:" + bigDecimalA.divide(bigDecimalB, RoundingMode.HALF_UP));
}
}
輸出:
加法計算:94109548214.6190477104198194
減法計算:75014240908.1099851928888886
乘法計算:807367681534936403630.5129638756291550362695127463516
除法計算:8.856824685145518
通過當前的程序代碼執行的話可以非常清楚的發現,在使用BigDecimal類的處理過程之中,需要針對除法進行四舍五入的進位配置,所以對于四舍五入的功能處理也可以通過BigDecimal類的方法來完成。
范例:通過BigDecimal實現準確位數的四舍五入
public static double round(double num,int scale){
return new BigDecimal(num).divide(new BigDecimal(1),scale,RoundingMode.HALF_UP).doubleValue();
}
在實際的開發過程中,如果面臨數據的精準度很高的情況下,千萬不要再去使用double,把所有的double都替換為BigDecimal。如果沒有非常復雜的小數計算,那么還使用普通的double即可。