国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

浮點型(float、double)進行計算時不能精確計算(轉)

2019-11-11 05:00:36
字體:
來源:轉載
供稿:網友
一提到java里面的商業計算,我們都知道不能用float和double,因為他們無法 進行精確計算。但是Java的設計者給編程人員提供了一個很有用的類BigDecimal,他可以完善float和double類無法進行精確計算的缺 憾。BigDecimal類位于java.maths類包下。首先我們來看下如何構造一個BigDecimal對象。它的構造函數很多,我挑最常用的兩個 來演示一下:一個就是BigDecimal(double val),另一個就是BigDecimal(String str)。下面是兩個浮點數相減的例子來說明:public static void main(String[] args) {double a = 1;double b = 0.9;BigDecimal a1 = new BigDecimal(Double.toString(a));BigDecimal b1 = new BigDecimal(Double.toString(b));BigDecimal a2 = new BigDecimal(a);BigDecimal b2 = new BigDecimal(b);double c = a1.subtract(b1).doubleValue();double d = a2.subtract(b2).doubleValue();System.out.PRintln(“c=”+c);System.out.println(“d=”+d);}結果為:c=0.1d=0.09999999999999998可以得出結論:利用double作為參數的構造函數,無法精確構造一個BigDecimal對象,需要自己指定一個上下文的環境,也就是指定精確位。而利用String對象作為參數傳入的構造函數能精確的構造出一個BigDecimal對象。
上一篇:CmakeLists實踐(2)

下一篇:運算符操作

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 永善县| 东明县| 广德县| 司法| 阳高县| 库伦旗| 永登县| 青田县| 大化| 义乌市| 娄底市| 遵化市| 股票| 苏尼特右旗| 正镶白旗| 吉木萨尔县| 龙海市| 平谷区| 陇川县| 厦门市| 眉山市| 闸北区| 梓潼县| 甘孜| 云龙县| 陆丰市| 措美县| 喀喇| 大兴区| 许昌县| 永修县| 漳浦县| 时尚| 吉首市| 财经| 东山县| 庐江县| 聂拉木县| 陈巴尔虎旗| 项城市| 莆田市|