欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

解决计算精度问题: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