本人是萌新程序员,读研以来没有怎么学习过技术,现准备突击学习来应对秋招,如果有错误欢迎指出,感谢各位,希望各位不吝赐教
1 内容简介
在Java环境中,浮点数的运算有时会造成精度丢失,所以采用BigDecimal来进行浮点数运算.
2 代码示例与讲解
在计算机中保存一个小数,所占用的位置宽度是有限的,但是有些分数或者浮点数是无限小数,所以计算机在存储小数时会进行截断处理,这就造成了一定的精度损失.
public class Test {
public static void main(String[] args) {
float a = 1.8f - 1.7f;
float b = 2.0f - 1.9f;
System.out.println("a:" + a);
System.out.println("b:" + b);
System.out.println(a == b);
}
}
/*
* output:
* a:0.099999905
* b:0.100000024
* false
* */
BigDecimal在进行浮点数计算时,不会造成精度损失.
import java.math.BigDecimal;
public class Test {
public static void main(String[] args) {
BigDecimal a = new BigDecimal("1.8");
BigDecimal b = new BigDecimal("1.7");
System.out.println("a:" + a);
System.out.println("b:" + b);
System.out.println("a+b:" + a.subtract(b));
}
}
/*
* output:
* a:1.8
* b:1.7
* a+b:0.1
* */
3 总结
1.BigDecimal
由三个主要部分组成:未缩放值(unscaled value
)、小数点位置(scale
)和精度(precision
)。未缩放值可以是一个 BigInteger
或一个 long
类型的值(intCompact
),用于存储整数部分。scale
表示小数点后的位数,如果 scale
为负数,则未缩放值会乘以 10 的相应次方。
2.如果未缩放值可以被精确地表示为一个 long
值(即其绝对值小于等于 Long.MAX_VALUE
),则使用 intCompact
字段存储该值,以节省空间并提高性能。如果未缩放值太大,不能存储在 long
中,则使用 BigInteger
类型的 intVal
字段存储。
3.BigDecimal
对象是不可变的,这意味着一旦创建,其值就不能被改变。这使得线程安全地使用 BigDecimal
对象成为可能。
4.BigDecimal
的实现考虑了性能,例如,通过使用 intCompact
字段存储较小的数值,以及通过缓存和重用常见的 BigDecimal
值(如 0 到 10)。