久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

完美解決java double數相加和相減的方案

瀏覽:47日期:2022-08-18 08:21:27

我就廢話不多說了,大家還是直接看代碼吧~

/** * double的計算不精確,會有類似0.0000000000000002的誤差,正確的方法是使用BigDecimal或者用整型 * 整型地方法適合于貨幣精度已知的情況,比如12.11+1.10轉成1211+110計算,最后再/100即可 * 以下是摘抄的BigDecimal方法: */ public class DoubleUtils implements Serializable { private static final long serialVersionUID = -3345205828566485102L; // 默認除法運算精度 private static final Integer DEF_DIV_SCALE = 2; /** * 提供精確的加法運算。 * * @param value1 被加數 * @param value2 加數 * @return 兩個參數的和 */ public static Double add(Double value1, Double value2) { BigDecimal b1 = new BigDecimal(Double.toString(value1)); BigDecimal b2 = new BigDecimal(Double.toString(value2)); return b1.add(b2).doubleValue(); } /** * 提供精確的減法運算。 * * @param value1 被減數 * @param value2 減數 * @return 兩個參數的差 */ public static double sub(Double value1, Double value2) { BigDecimal b1 = new BigDecimal(Double.toString(value1)); BigDecimal b2 = new BigDecimal(Double.toString(value2)); return b1.subtract(b2).doubleValue(); } /** * 提供精確的乘法運算。 * * @param value1 被乘數 * @param value2 乘數 * @return 兩個參數的積 */ public static Double mul(Double value1, Double value2) { BigDecimal b1 = new BigDecimal(Double.toString(value1)); BigDecimal b2 = new BigDecimal(Double.toString(value2)); return b1.multiply(b2).doubleValue(); } /** * 提供(相對)精確的除法運算,當發生除不盡的情況時, 精確到小數點以后10位,以后的數字四舍五入。 * * @param dividend 被除數 * @param divisor 除數 * @return 兩個參數的商 */ public static Double divide(Double dividend, Double divisor) { return divide(dividend, divisor, DEF_DIV_SCALE); } /** * 提供(相對)精確的除法運算。 當發生除不盡的情況時,由scale參數指定精度,以后的數字四舍五入。 * * @param dividend 被除數 * @param divisor 除數 * @param scale 表示表示需要精確到小數點以后幾位。 * @return 兩個參數的商 */ public static Double divide(Double dividend, Double divisor, Integer scale) { if (scale < 0) { throw new IllegalArgumentException('The scale must be a positive integer or zero'); } BigDecimal b1 = new BigDecimal(Double.toString(dividend)); BigDecimal b2 = new BigDecimal(Double.toString(divisor)); return b1.divide(b2, scale,RoundingMode.HALF_UP).doubleValue(); } /** * 提供指定數值的(精確)小數位四舍五入處理。 * * @param value 需要四舍五入的數字 * @param scale 小數點后保留幾位 * @return 四舍五入后的結果 */ public static double round(double value,int scale){ if(scale<0){ throw new IllegalArgumentException('The scale must be a positive integer or zero'); } BigDecimal b = new BigDecimal(Double.toString(value)); BigDecimal one = new BigDecimal('1'); return b.divide(one,scale, RoundingMode.HALF_UP).doubleValue(); } }

javascript double相互運算出現小數問題解決

//加法function numAdd(num1, num2) { var baseNum, baseNum1, baseNum2; try { baseNum1 = num1.toString().split('.')[1].length; } catch (e) { baseNum1 = 0; } try { baseNum2 = num2.toString().split('.')[1].length; } catch (e) { baseNum2 = 0; } baseNum = Math.pow(10, Math.max(baseNum1, baseNum2)); var precision = (baseNum1 >= baseNum2) ? baseNum1 : baseNum2;//精度 return ((num1 * baseNum + num2 * baseNum) / baseNum).toFixed(precision);; }; //減法運算function numSub(num1, num2) { var baseNum, baseNum1, baseNum2; try { baseNum1 = num1.toString().split('.')[1].length; } catch (e) { baseNum1 = 0; } try { baseNum2 = num2.toString().split('.')[1].length; } catch (e) { baseNum2 = 0; } baseNum = Math.pow(10, Math.max(baseNum1, baseNum2)); var precision = (baseNum1 >= baseNum2) ? baseNum1 : baseNum2; return ((num1 * baseNum - num2 * baseNum) / baseNum).toFixed(precision); }; // 乘法運算 function numMulti(num1, num2) { var baseNum = 0; try { baseNum += num1.toString().split('.')[1].length; } catch (e) { } try { baseNum += num2.toString().split('.')[1].length; } catch (e) { } return Number(num1.toString().replace('.', '')) * Number(num2.toString().replace('.', '')) / Math.pow(10, baseNum); }; // 除法運算,避免數據相除小數點后產生多位數和計算精度損失。 function numDiv(num1, num2) { var baseNum1 = 0, baseNum2 = 0; var baseNum3, baseNum4; try { baseNum1 = num1.toString().split('.')[1].length; } catch (e) { baseNum1 = 0; } try { baseNum2 = num2.toString().split('.')[1].length; } catch (e) { baseNum2 = 0; } with (Math) { baseNum3 = Number(num1.toString().replace('.', '')); baseNum4 = Number(num2.toString().replace('.', '')); return (baseNum3 / baseNum4) * pow(10, baseNum2 - baseNum1); } };

補充:java中double、float 類型相同數相減不為0

大家在java編程的時候經常會遇到這種情況,兩個float或者double類型的相減,但是他們結果不為0,那我們該怎么解決呢,下面小編告訴大家一種方法,希望對大家有用。

1、大家先看看這種情況,兩個相同的浮點數相減不為0,

完美解決java double數相加和相減的方案

2、再說下BigDecimal,Java在java.math包中提供的API類BigDecimal,用來對超過16位有效位的數進行精確的運算。雙精度浮點型變量double可以處理16位有效數。在實際應用中,需要對更大或者更小的數進行運算和處理。這時我們就要用BigDecimal,用的時候導入包java.math.BigDecimal;

完美解決java double數相加和相減的方案

3、我們既然知道要用BigDecimal就行轉化,下面就試試

完美解決java double數相加和相減的方案

4、比較之后我們很容易知道BigDecimal對double、float 類型相同數相減不為0是個有效的方法了

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: Java
相關文章:
主站蜘蛛池模板: 999久久久国产999久久久 | 欧美一极视频 | 在线国产一区 | 一区免费| 国产精品1页 | 亚洲一区中文字幕在线观看 | 国产中文在线 | 成人免费淫片视频观 | 国产成人精品一区二区三区视频 | 国产色| 看免费av| 日韩中文字幕一区二区高清99 | 欧美一级大片免费 | 亚洲精品乱码久久久久久蜜桃不卡 | 一区二区亚洲 | 色av综合在线| www.一区| 久久黄网 | 国产精品国产 | 黄色免费高清视频 | 国产亚洲精品精品国产亚洲综合 | 四虎影音| 久久精品99国产精品亚洲最刺激 | 特黄特色大片免费视频观看 | 天天操夜夜操 | 日韩av免费看 | 成人综合在线观看 | 国产精品一区亚洲二区日本三区 | 日本狠狠干 | 国产不卡免费视频 | 国产一区二区视频免费 | 国产黄色免费视频 | 精品国产仑片一区二区三区 | 一区二区三区在线免费 | 日韩国产在线观看 | 精品国产免费久久久久久尖叫 | 亚洲高清不卡视频 | 日韩在线观看成人 | 久久99精品久久久久蜜臀 | 亚洲一区二区久久 | 久久91av |