首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

BigDecimal 应用小记

2013-01-20 
BigDecimal 使用小记今天看API 发现BigDecimal一个问题 记录一下public BigDecimal(double val) 构造方法

BigDecimal 使用小记
今天看API 发现BigDecimal一个问题 记录一下
public BigDecimal(double val) 构造方法
中说明
Note:   the   results   of   this   constructor   can   be   somewhat   unpredictable

下面代码大家看下就明白了

import java.math.BigDecimal;/** * 由於Java的簡單類型不能夠精確的對浮點數進行運算,這個工具類提供精 確的浮點數運算,包括加減乘除和四捨五入。 */public class Arith {// 默認除法運算精度private static final int DEF_DIV_SCALE = 10;// 這個類不能實例化private Arith() {}/** * 提供精確的加法運算。 *  * @param v1 *            被加數 * @param v2 *            加數 * @return 兩個參數的和 */public static double add(double v1, double v2) {BigDecimal b1 = new BigDecimal(Double.toString(v1));BigDecimal b2 = new BigDecimal(Double.toString(v2));return b1.add(b2).doubleValue();}/** * 提供精確的減法運算。 *  * @param v1 *            被減數 * @param v2 *            減數 * @return 兩個參數的差 */public static double sub(double v1, double v2) {BigDecimal b1 = new BigDecimal(Double.toString(v1));BigDecimal b2 = new BigDecimal(Double.toString(v2));return b1.subtract(b2).doubleValue();}/** * 提供精確的乘法運算。 *  * @param v1 *            被乘數 * @param v2 *            乘數 * @return 兩個參數的積 */public static double mul(double v1, double v2) {BigDecimal b1 = new BigDecimal(Double.toString(v1));BigDecimal b2 = new BigDecimal(Double.toString(v2));return b1.multiply(b2).doubleValue();}/** * 提供(相對)精確的除法運算,當發生除不盡的情況時,精確到 小數點以後10位元,以後的數字四捨五入。 *  * @param v1 *            被除數 * @param v2 *            除數 * @return 兩個參數的商 */public static double div(double v1, double v2) {return div(v1, v2, DEF_DIV_SCALE);}/** * 提供(相對)精確的除法運算。當發生除不盡的情況時,由scale參數指 定精度,以後的數字四捨五入。 *  * @param v1 *            被除數 * @param v2 *            除數 * @param scale *            表示表示需要精確到小數點以後幾位。 * @return 兩個參數的商 */public static double div(double v1, double v2, int scale) {if (scale < 0) {throw new IllegalArgumentException("The scale must be a positive integer or zero");}BigDecimal b1 = new BigDecimal(Double.toString(v1));BigDecimal b2 = new BigDecimal(Double.toString(v2));return b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();}/** * 提供精確的小數位四捨五入處理。 *  * @param v *            需要四捨五入的數位 * @param scale *            小數點後保留幾位 * @return 四捨五入後的結果 */public static double round(double v, int scale) {if (scale < 0) {throw new IllegalArgumentException("The scale must be a positive integer or zero");}BigDecimal b = new BigDecimal(Double.toString(v));BigDecimal one = new BigDecimal("1");return b.divide(one, scale, BigDecimal.ROUND_HALF_UP).doubleValue();}}

热点排行