Java中BigDecimal類的使用詳解
不論是float 還是double都是浮點數,而計算機是二進制的,浮點數會失去一定的精確度。Java在java.math包中提供的API類BigDecimal,用來對超過16位有效位的數進行精確的運算。BigDecimal所創建的是對象,我們不能使用傳統的+、-、*、/等算術運算符直接對其對象進行數學運算,而必須調用其相對應的方法。方法中的參數也必須是BigDecimal的對象。構造器是類的特殊方法,專門用來創建對象,特別是帶有參數的對象。
一、BigDecimal轉換取Double數據
假設我們有一個數據是:Double num = 123456789.98;我們用java怎么取到這個數值呢。經過筆者測試:
Double num = 123456789.98; BigDecimal bg1=new BigDecimal(num); BigDecimal bg2=new BigDecimal(num + ''); System.err.println(num); System.err.println(bg1); System.err.println(bg2);
我們得到:
所以呢,取Double數據的方法是:
Double num = 123456789.98; BigDecimal bg2=new BigDecimal(num + '');
二、BigDecimal去掉科學計數法
java.text.NumberFormat NF = java.text.NumberFormat.getInstance(); NF.setGroupingUsed(false);//去掉科學計數法顯示 System.err.println('d:='+NF.format(num));
三、BigDecimal的加法減法乘法除法運算。
常規我們想到的加法:Double aa = num + num;System.err.println(aa);BigDecimal bb =new BigDecimal(aa + ''); System.err.println(bb);
快拿計算機算算,是對的吧。接下來咱們看,正規一點的寫法
BigDecimal b1 = new BigDecimal(Double.toString(num)); BigDecimal b2 = new BigDecimal(Double.toString(num)); System.err.println(b1.add(b2).doubleValue()); BigDecimal cc =new BigDecimal(b1.add(b2).doubleValue()); System.err.println(cc);
就測試結果而言呢,還是按照我們常規的想法走吧。b1.subtract(b2).doubleValue();//減法b1.multiply(b2).doubleValue();//乘法b1.divide(b2,scale,BigDecimal.ROUND_HALF_UP).doubleValue();//除法四、接下來,我們測試最后一個乘法這個精度可能超出了Double的精度,我們減小一下6789.98 x 6789.98 =46103828.4004上代碼測試:常規:
Double num = 6789.98; Double dd = num * num; System.err.println(dd); BigDecimal ee =new BigDecimal(dd + ''); System.err.println(ee);
精確:
Double yysds = 6789.98; BigDecimal b1 = new BigDecimal(Double.toString(yysds)); BigDecimal b2 = new BigDecimal(Double.toString(yysds)); System.err.println(b1.multiply(b2).doubleValue()); BigDecimal cc =new BigDecimal(b1.multiply(b2).doubleValue()); System.err.println(cc);
上結果
看來涉及小數的計算,還是需要留意的。其實筆者總結:取Double的值,轉化一下。計算的時候就按照常規的方法來計算,只是取值的時候轉一下。
到此這篇關于Java中BigDecimal類的使用詳解的文章就介紹到這了,更多相關Java中BigDecimal類內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章: