java中BigDecimal的操作方法
程序员文章站
2024-03-01 10:37:52
本文实例讲述了java中bigdecimal的操作方法。分享给大家供大家参考。具体分析如下:
由于double,float的精度不够,因此在进行商业计算的时候要使用的bi...
本文实例讲述了java中bigdecimal的操作方法。分享给大家供大家参考。具体分析如下:
由于double,float的精度不够,因此在进行商业计算的时候要使用的bigdecimal。bigdecimal对象创建如下:
复制代码 代码如下:
bigdecimal b = new bigdecimal("12.000001");
system.out.println(b);
system.out.println(b);
输出结果为:12.000001;
bigdecimal在创建的时候可以传入string和double,但是最好使用string,至于原因看看如下代码就知道了:
复制代码 代码如下:
bigdecimal b = new bigdecimal("12.000001");
system.out.println(b);
bigdecimal c = new bigdecimal(12.01);
system.out.println(c);
system.out.println(b);
bigdecimal c = new bigdecimal(12.01);
system.out.println(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 bd1.add(bd2);
}
//减法
public static bigdecimal subtract(string num1, string num2) {
bigdecimal bd1 = new bigdecimal(num1);
bigdecimal bd2 = new bigdecimal(num2);
return bd1.subtract(bd2);
}
//乘法
public static bigdecimal multiply(string num1, string num2) {
bigdecimal bd1 = new bigdecimal(num1);
bigdecimal bd2 = new bigdecimal(num2);
return bd1.multiply(bd2);
}
//除法
public static bigdecimal divide(string num1, string num2, int i) {
bigdecimal bd1 = new bigdecimal(num1);
bigdecimal bd2 = new bigdecimal(num2);
// i是要保留的位数, bigdecimal.round_half_up 表示四舍五入的规则
return bd1.divide(bd2, i, bigdecimal.round_half_down);
}
public static bigdecimal add(string num1, string num2) {
bigdecimal bd1 = new bigdecimal(num1);
bigdecimal bd2 = new bigdecimal(num2);
return bd1.add(bd2);
}
//减法
public static bigdecimal subtract(string num1, string num2) {
bigdecimal bd1 = new bigdecimal(num1);
bigdecimal bd2 = new bigdecimal(num2);
return bd1.subtract(bd2);
}
//乘法
public static bigdecimal multiply(string num1, string num2) {
bigdecimal bd1 = new bigdecimal(num1);
bigdecimal bd2 = new bigdecimal(num2);
return bd1.multiply(bd2);
}
//除法
public static bigdecimal divide(string num1, string num2, int i) {
bigdecimal bd1 = new bigdecimal(num1);
bigdecimal bd2 = new bigdecimal(num2);
// i是要保留的位数, bigdecimal.round_half_up 表示四舍五入的规则
return bd1.divide(bd2, i, bigdecimal.round_half_down);
}
需要强调一下除法,第三个参数为是否四舍五入,
round_half_down表示遇5不进1,即1.5->1;
round_half_up表示遇5进1,即1.5->2;
但是有点需要注意:
当我们使用round_half_down时
复制代码 代码如下:
system.out.println(this.divide("67.75", "5",4));
system.out.println(this.divide("67.75", "5",1));
system.out.println("-------");
system.out.println(this.divide("67.751", "5",4));
system.out.println(this.divide("67.751", "5",1));
system.out.println(this.divide("67.75", "5",1));
system.out.println("-------");
system.out.println(this.divide("67.751", "5",4));
system.out.println(this.divide("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程序设计有所帮助。
上一篇: DOM属性用法速查手册第1/4页
下一篇: java通过控制鼠标实现屏幕广播的方法