Java中BigDecimal類的使用詳解
不論是float 還是double都是浮點(diǎn)數(shù),而計(jì)算機(jī)是二進(jìn)制的,浮點(diǎn)數(shù)會(huì)失去一定的精確度。Java在java.math包中提供的API類BigDecimal,用來(lái)對(duì)超過(guò)16位有效位的數(shù)進(jìn)行精確的運(yùn)算。BigDecimal所創(chuàng)建的是對(duì)象,我們不能使用傳統(tǒng)的+、-、*、/等算術(shù)運(yùn)算符直接對(duì)其對(duì)象進(jìn)行數(shù)學(xué)運(yùn)算,而必須調(diào)用其相對(duì)應(yīng)的方法。方法中的參數(shù)也必須是BigDecimal的對(duì)象。構(gòu)造器是類的特殊方法,專門用來(lái)創(chuàng)建對(duì)象,特別是帶有參數(shù)的對(duì)象。
一、BigDecimal轉(zhuǎn)換取Double數(shù)據(jù)
假設(shè)我們有一個(gè)數(shù)據(jù)是:Double num = 123456789.98;我們用java怎么取到這個(gè)數(shù)值呢。經(jīng)過(guò)筆者測(cè)試:
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ī)算算,是對(duì)的吧。接下來(lái)咱們看,正規(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);
就測(cè)試結(jié)果而言呢,還是按照我們常規(guī)的想法走吧。b1.subtract(b2).doubleValue();//減法b1.multiply(b2).doubleValue();//乘法b1.divide(b2,scale,BigDecimal.ROUND_HALF_UP).doubleValue();//除法四、接下來(lái),我們測(cè)試最后一個(gè)乘法這個(gè)精度可能超出了Double的精度,我們減小一下6789.98 x 6789.98 =46103828.4004上代碼測(cè)試:常規(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é)果
看來(lái)涉及小數(shù)的計(jì)算,還是需要留意的。其實(shí)筆者總結(jié):取Double的值,轉(zhuǎn)化一下。計(jì)算的時(shí)候就按照常規(guī)的方法來(lái)計(jì)算,只是取值的時(shí)候轉(zhuǎn)一下。
到此這篇關(guān)于Java中BigDecimal類的使用詳解的文章就介紹到這了,更多相關(guān)Java中BigDecimal類內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. python中scrapy處理項(xiàng)目數(shù)據(jù)的實(shí)例分析2. Python中讀取文件名中的數(shù)字的實(shí)例詳解3. 在idea中為注釋標(biāo)記作者日期操作4. 通過(guò)Ajax方式綁定select選項(xiàng)數(shù)據(jù)的實(shí)例5. JSP頁(yè)面的靜態(tài)包含和動(dòng)態(tài)包含使用方法6. ASP.Net Core對(duì)USB攝像頭進(jìn)行截圖7. ASP.NET MVC使用Boostrap實(shí)現(xiàn)產(chǎn)品展示、查詢、排序、分頁(yè)8. .net如何優(yōu)雅的使用EFCore實(shí)例詳解9. 使用AJAX(包含正則表達(dá)式)驗(yàn)證用戶登錄的步驟10. ajax動(dòng)態(tài)加載json數(shù)據(jù)并詳細(xì)解析
