Java中BigDecimal類的使用詳解
不論是float 還是double都是浮點(diǎn)數(shù),而計(jì)算機(jī)是二進(jìn)制的,浮點(diǎn)數(shù)會失去一定的精確度。Java在java.math包中提供的API類BigDecimal,用來對超過16位有效位的數(shù)進(jìn)行精確的運(yùn)算。BigDecimal所創(chuàng)建的是對象,我們不能使用傳統(tǒng)的+、-、*、/等算術(shù)運(yùn)算符直接對其對象進(jìn)行數(shù)學(xué)運(yùn)算,而必須調(diào)用其相對應(yīng)的方法。方法中的參數(shù)也必須是BigDecimal的對象。構(gòu)造器是類的特殊方法,專門用來創(chuàng)建對象,特別是帶有參數(shù)的對象。
一、BigDecimal轉(zhuǎn)換取Double數(shù)據(jù)
假設(shè)我們有一個(gè)數(shù)據(jù)是:Double num = 123456789.98;我們用java怎么取到這個(gè)數(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é)計(jì)數(shù)法
java.text.NumberFormat NF = java.text.NumberFormat.getInstance(); NF.setGroupingUsed(false);//去掉科學(xué)計(jì)數(shù)法顯示 System.err.println('d:='+NF.format(num));
三、BigDecimal的加法減法乘法除法運(yùn)算。
常規(guī)我們想到的加法:Double aa = num + num;System.err.println(aa);BigDecimal bb =new BigDecimal(aa + ''); System.err.println(bb);
快拿計(jì)算機(jī)算算,是對的吧。接下來咱們看,正規(guī)一點(diǎn)的寫法
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();//除法四、接下來,我們測試最后一個(gè)乘法這個(gè)精度可能超出了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ù)的計(jì)算,還是需要留意的。其實(shí)筆者總結(jié):取Double的值,轉(zhuǎn)化一下。計(jì)算的時(shí)候就按照常規(guī)的方法來計(jì)算,只是取值的時(shí)候轉(zhuǎn)一下。
到此這篇關(guān)于Java中BigDecimal類的使用詳解的文章就介紹到這了,更多相關(guān)Java中BigDecimal類內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. React+umi+typeScript創(chuàng)建項(xiàng)目的過程2. ASP.NET Core 5.0中的Host.CreateDefaultBuilder執(zhí)行過程解析3. SharePoint Server 2019新特性介紹4. ASP中常用的22個(gè)FSO文件操作函數(shù)整理5. 三個(gè)不常見的 HTML5 實(shí)用新特性簡介6. ASP調(diào)用WebService轉(zhuǎn)化成JSON數(shù)據(jù),附j(luò)son.min.asp7. .Net core 的熱插拔機(jī)制的深入探索及卸載問題求救指南8. 無線標(biāo)記語言(WML)基礎(chǔ)之WMLScript 基礎(chǔ)第1/2頁9. 讀大數(shù)據(jù)量的XML文件的讀取問題10. 解決ASP中http狀態(tài)跳轉(zhuǎn)返回錯(cuò)誤頁的問題
