BigDecimal類java
對於不須要任何準確計算精度的數字能夠直接使用float或double,可是若是須要精確計算的結果,則必須使用BigDecimal類,並且使用BigDecimal類也能夠進行大數的操做。BigDecimal類的經常使用方法如表11-15所示。ide
表11-15 BigDecimal類的經常使用方法函數
序號spa |
方 法code |
類型blog |
描 述ip |
1ci |
public BigDecimal(double val)字符串 |
構造get |
將double表示形式轉換 爲BigDecimal |
2 |
public BigDecimal(int val) |
構造 |
將int表示形式轉換爲 BigDecimal |
3 |
public BigDecimal(String val) |
構造 |
將字符串表示 形式轉換爲BigDecimal |
4 |
public BigDecimal add(BigDecimal augend) |
普通 |
加法 |
5 |
public BigDecimal subtract(BigDecimal |
普通 |
減法 |
6 |
public BigDecimal multiply(BigDecimal |
普通 |
乘法 |
7 |
public BigDecimal divide(BigDecimal |
普通 |
除法 |
範例:進行四捨五入的四則運算
package org.lxh.demo11.numberdemo; import java.math.BigDecimal; class MyMath { public static double add(double d1, double d2) { // 進行加法運算 BigDecimal b1 = new BigDecimal(d1); BigDecimal b2 = new BigDecimal(d2); return b1.add(b2).doubleValue(); } public static double sub(double d1, double d2) { // 進行減法運算 BigDecimal b1 = new BigDecimal(d1); BigDecimal b2 = new BigDecimal(d2); return b1.subtract(b2).doubleValue(); } public static double mul(double d1, double d2) { // 進行乘法運算 BigDecimal b1 = new BigDecimal(d1); BigDecimal b2 = new BigDecimal(d2); return b1.multiply(b2).doubleValue(); } public static double div(double d1, double d2,int len) {// 進行除法運算 BigDecimal b1 = new BigDecimal(d1); BigDecimal b2 = new BigDecimal(d2); return b1.divide(b2,len,BigDecimal. ROUND_HALF_UP).doubleValue(); } public static double round(double d, int len) { // 進行四捨五入 操做 BigDecimal b1 = new BigDecimal(d); BigDecimal b2 = new BigDecimal(1); // 任何一個數字除以1都是原數字 // ROUND_HALF_UP是BigDecimal的一個常量, 表示進行四捨五入的操做 return b1.divide(b2, len,BigDecimal. ROUND_HALF_UP).doubleValue(); } } public class BigDecimalDemo01 { public static void main(String[] args) { System.out.println("加法運算:" + MyMath.round(MyMath.add(10.345, 3.333), 1)); System.out.println("乘法運算:" + MyMath.round(MyMath.mul(10.345, 3.333), 3)); System.out.println("除法運算:" + MyMath.div(10.345, 3.333, 3)); System.out.println("減法運算:" + MyMath.round(MyMath.sub(10.345, 3.333), 3)); } }
BigDecimal是Java中用來表示任意精確浮點數運算的類,在BigDecimal中,使用unscaledValue × 10-scale來表示一個浮點數。其中,unscaledValue是一個BigInteger,scale是一個int。從這個表示方法來看,BigDecimal只能標識有限小數,不過能夠表示的數據範圍遠遠大於double,在實際應用中基本足夠了。
System.out.println(new BigDecimal(0.1).toString()); // 0.1000000000000000055511151231257827021181583404541015625 System.out.println(new BigDecimal("0.1").toString()); // 0.1 System.out.println(new BigDecimal( Double.toString(0.1000000000000000055511151231257827021181583404541015625)).toString());// 0.1 System.out.println(new BigDecimal(Double.toString(0.1)).toString()); // 0.1
分析一下上面代碼的問題(註釋的內容表示此語句的輸出)
int x=(int)1023.99999999999999; // x=1024爲何?
緣由仍是在於二進制沒法精確地表示某些十進制小數,所以1023.99999999999999在編譯以後的double值變成了1024。
double d = 1023.99999999999999; int x = (int) d; System.out.println(new BigDecimal(d).toString()); // 1024 System.out.println(Long.toHexString(Double.doubleToRawLongBits(d))); // 4090000000000000 System.out.println(x); // 1024
前面提過BigDecimal能夠精確地把double表示出來還記得吧。