JavaGuide学习日记-BigDecimal

        本人是萌新程序员,读研以来没有怎么学习过技术,现准备突击学习来应对秋招,如果有错误欢迎指出,感谢各位,希望各位不吝赐教

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)。

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值