java中BigDecimal的操作方法详解

由于double,float的精度不够,因此在进行商业计算的时候要使用的BigDecimAL。BigDecimal对象创建如下:

java中BigDecimal的操作方法详解

复制代码 代码如下:BigDecimal b = new BigDecimal("12.000001");

tln(b);

输出结果为:12.000001;

BigDecimal在创建的时候可以传入String和double,但是最好使用String,至于原因看看如下代码就知道了:

复制代码 代码如下:BigDecimal b = new BigDecimal("12.000001");

tln(b);

BigDecimal c = new BigDecimal(12.01);

tln(c);

运行结果为:

12.000001

12.0099999999999997868371792719699442386627197265625

可以看出在传入double的时候精度会丢失。

BigDecimal其他操作如下:

复制代码 代码如下: //加法

public static BigDecimal add(String num1, String num2) {

BigDecimal bd1 = new BigDecimal(num1);

BigDecimal bd2 = new BigDecimal(num2);

return (bd2);

}

//减法

public static BigDecimal subtract(String num1, String num2) {

BigDecimal bd1 = new BigDecimal(num1);

BigDecimal bd2 = new BigDecimal(num2);

return ract(bd2);

}

//乘法

public static BigDecimal multiply(String num1, String num2) {

BigDecimal bd1 = new BigDecimal(num1);

BigDecimal bd2 = new BigDecimal(num2);

return iply(bd2);

}

//除法

public static BigDecimal divide(String num1, String num2, int i) {

BigDecimal bd1 = new BigDecimal(num1);

BigDecimal bd2 = new BigDecimal(num2);

// i是要保留的.位数, D_HALF_UP 表示四舍五入的规则

return de(bd2, i, D_HALF_DOWN);

}

需要强调一下除法,第三个参数为是否四舍五入,

ROUND_HALF_DOWN表示遇5不进1,即1.5->1;

ROUND_HALF_UP表示遇5进1,即1.5->2;

但是有点需要注意:

当我们使用ROUND_HALF_DOWN时

复制代码 代码如下:tln(de("67.75", "5",4));

tln(de("67.75", "5",1));

tln("-------");

tln(de("67.751", "5",4));

tln(de("67.751", "5",1));

运行结果如下:

13.5500

13.5

-------

13.5502

13.6

我就纳闷了,按道理第二个结果应该是13.5啊!怎么成了13.6。后来经过多次测试,想了一下,这个四舍五入不是按照精度位后面移位与5做比较,而是按照精度位后的所有的数据与5做比较,也就是说:13.5500精确到一位,则用0.0500与5比较,而13.5502精确到一位,则用0.0502与5比较,比5大,所以就向上收。

希望本文所述对大家的Java程序设计有所帮助。