解决计算精度问题:BigDecimal
程序员文章站
2023-11-23 16:04:10
BigDecimal类 BigDecimal所在包:java.math,不可变的、任意精度的有符号十进制数。BigDecimal 由任意精度的整数非标度值 和 32 位的整数标度 (scale) 组成。 对于不需要任何准确计算精度的数字可以直接使用float或double,但是如果需要精确计算的结果 ......
bigdecimal类
bigdecimal所在包:java.math,不可变的、任意精度的有符号十进制数。bigdecimal 由任意精度的整数非标度值 和 32 位的整数标度 (scale) 组成。
对于不需要任何准确计算精度的数字可以直接使用float或double,但是如果需要精确计算的结果,则必须使用bigdecimal类,而且使用bigdecimal类也可以进行大数的操作
dobule例子
1 public class testmath { 2 3 public static void main(string[] args) { 4 double a1 = 0.1; 5 double a2 = 0.2; 6 7 double a3 = a1 + a2; 8 system.out.println(a1 + " + " + a2 + " = " + a3); 9 } 10 11 }
猜猜结果是多少?
结果:0.1 + 0.2 = 0.30000000000000004
(常识应该是0.1 + 0.2 = 0.3)
bigdecimal例子
1 import java.math.bigdecimal; 2 3 public class testmath { 4 5 public static void main(string[] args) { 6 double a1 = 0.1; 7 double a2 = 0.2; 8 9 double a3 = a1 + a2; 10 system.out.println("使用double类型计算结果:" + a1 + " + " + a2 + " = " + a3); 11 12 bigdecimal b1 = new bigdecimal("0.1"); 13 bigdecimal b2 = new bigdecimal("0.2"); 14 15 bigdecimal b3 = b1.add(b2); 16 17 system.out.println("使用bigdecimal类型计算结果:" + b1 + " + " + b2 + " = " + b3); 18 } 19 20 }
输出结果:
使用double类型计算结果:0.1 + 0.2 = 0.30000000000000004
使用bigdecimal类型计算结果:0.1 + 0.2 = 0.3