Java中BigDecimal類的使用詳解
不論是float 還是double都是浮點數(shù),而計算機是二進制的,浮點數(shù)會失去一定的精確度。Java在java.math包中提供的API類BigDecimal,用來對超過16位有效位的數(shù)進行精確的運算。BigDecimal所創(chuàng)建的是對象,我們不能使用傳統(tǒng)的+、-、*、/等算術(shù)運算符直接對其對象進行數(shù)學(xué)運算,而必須調(diào)用其相對應(yīng)的方法。方法中的參數(shù)也必須是BigDecimal的對象。構(gòu)造器是類的特殊方法,專門用來創(chuàng)建對象,特別是帶有參數(shù)的對象。
一、BigDecimal轉(zhuǎn)換取Double數(shù)據(jù)
假設(shè)我們有一個數(shù)據(jù)是:Double num = 123456789.98;我們用java怎么取到這個數(shù)值呢。經(jīng)過筆者測試:
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數(shù)據(jù)的方法是:
Double num = 123456789.98; BigDecimal bg2=new BigDecimal(num + '');
二、BigDecimal去掉科學(xué)計數(shù)法
java.text.NumberFormat NF = java.text.NumberFormat.getInstance(); NF.setGroupingUsed(false);//去掉科學(xué)計數(shù)法顯示 System.err.println('d:='+NF.format(num));
三、BigDecimal的加法減法乘法除法運算。
常規(guī)我們想到的加法:Double aa = num + num;System.err.println(aa);BigDecimal bb =new BigDecimal(aa + ''); System.err.println(bb);
快拿計算機算算,是對的吧。接下來咱們看,正規(guī)一點的寫法
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);
就測試結(jié)果而言呢,還是按照我們常規(guī)的想法走吧。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上代碼測試:常規(guī):
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);
上結(jié)果
看來涉及小數(shù)的計算,還是需要留意的。其實筆者總結(jié):取Double的值,轉(zhuǎn)化一下。計算的時候就按照常規(guī)的方法來計算,只是取值的時候轉(zhuǎn)一下。
到此這篇關(guān)于Java中BigDecimal類的使用詳解的文章就介紹到這了,更多相關(guān)Java中BigDecimal類內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. IntelliJ IDEA導(dǎo)入jar包的方法2. SSM框架JSP使用Layui實現(xiàn)layer彈出層效果3. 刪除docker里建立容器的操作方法4. IntelliJ IDEA導(dǎo)出項目的方法5. .Net中的Http請求調(diào)用詳解(Post與Get)6. 如果你恨一個程序員,忽悠他去做iOS開發(fā)7. JS如何在數(shù)組指定位置插入元素8. IDEA調(diào)試源碼小技巧之辨別抽象類或接口多種實現(xiàn)類的正確路徑9. java使用xfire搭建webservice服務(wù)的過程詳解10. Java源碼解析之ClassLoader
