Kotlin BigDecimal 精确计算

作者: MobMsg | 来源:发表于2019-01-09 18:30 被阅读2次

完整工具类

/**
 * 加、减、乘、除 高精度计算工具类  
 * @author lyl 20190191
 * */
object UtilsBigDecimal {

    // 需要精确至小数点后几位
    const val DECIMAL_POINT_NUMBER:Int = 2

    // 加法运算
    @JvmStatic
    fun add(d1:Double,d2:Double):Double = BigDecimal(d1).add(BigDecimal(d2)).setScale(DECIMAL_POINT_NUMBER,BigDecimal.ROUND_DOWN).toDouble()

    // 减法运算
    @JvmStatic
    fun sub(d1:Double,d2: Double):Double = BigDecimal(d1).subtract(BigDecimal(d2)).setScale(DECIMAL_POINT_NUMBER,BigDecimal.ROUND_DOWN).toDouble()

    // 乘法运算
    @JvmStatic
    fun mul(d1:Double,d2: Double,decimalPoint:Int):Double = BigDecimal(d1).multiply(BigDecimal(d2)).setScale(decimalPoint,BigDecimal.ROUND_DOWN).toDouble()

    // 除法运算
    @JvmStatic
    fun div(d1:Double,d2: Double):Double = BigDecimal(d1).divide(BigDecimal(d2)).setScale(DECIMAL_POINT_NUMBER,BigDecimal.ROUND_DOWN).toDouble()

}

setScale 方法用于格式化小数点

setScale(2)  //表示保留2位小数,默认是四舍五入方式

setScale(2, BigDecimal.ROUND_DOWN)  //删除多余的小数位,例如:2.125 → 2.12

setScale(2, BigDecimal.ROUND_UP)  //进位处理,例如:2.125 → 2.13

setScale(2, BigDecimal.ROUND_HALF_UP)  //四舍五入,例如:2.125 → 2.13

其它计算方式说明

  1. ROUND_UP
    舍入远离零的舍入模式。
    在丢弃非零部分之前始终增加数字(始终对非零舍弃部分前面的数字加1)。
    注意,此舍入模式始终不会减少计算值的大小。

  2. ROUND_DOWN
    接近零的舍入模式。
    在丢弃某部分之前始终不增加数字(从不对舍弃部分前面的数字加1,即截短)。
    注意,此舍入模式始终不会增加计算值的大小。

  3. ROUND_CEILING
    接近正无穷大的舍入模式。
    如果 BigDecimal 为正,则舍入行为与 ROUND_UP 相同;
    如果为负,则舍入行为与 ROUND_DOWN 相同。
    注意,此舍入模式始终不会减少计算值。

  4. ROUND_FLOOR
    接近负无穷大的舍入模式。
    如果 BigDecimal 为正,则舍入行为与 ROUND_DOWN 相同;
    如果为负,则舍入行为与 ROUND_UP 相同。
    注意,此舍入模式始终不会增加计算值。

  5. ROUND_HALF_UP
    向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。
    如果舍弃部分 >= 0.5,则舍入行为与 ROUND_UP 相同;否则舍入行为与 ROUND_DOWN 相同。
    注意,这是我们大多数人在小学时就学过的舍入模式(四舍五入)。

  6. ROUND_HALF_DOWN
    向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为上舍入的舍入模式。
    如果舍弃部分 > 0.5,则舍入行为与 ROUND_UP 相同;否则舍入行为与 ROUND_DOWN 相同(五舍六入)。

  7. ROUND_HALF_EVEN 银行家舍入法
    向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。
    如果舍弃部分左边的数字为奇数,则舍入行为与 ROUND_HALF_UP 相同;
    如果为偶数,则舍入行为与 ROUND_HALF_DOWN 相同。
    注意,在重复进行一系列计算时,此舍入模式可以将累加错误减到最小。
    此舍入模式也称为“银行家舍入法”,主要在美国使用。四舍六入,五分两种情况。
    如果前一位为奇数,则入位,否则舍去。
    以下例子为保留小数点1位,那么这种舍入方式下的结果。
    1.15>1.2 1.25>1.2

  8. ROUND_UNNECESSARY
    断言请求的操作具有精确的结果,因此不需要舍入。
    如果对获得精确结果的操作指定此舍入模式,则抛出ArithmeticException。

完毕。

相关文章

  • Kotlin BigDecimal 精确计算

    完整工具类 setScale 方法用于格式化小数点 其它计算方式说明 ROUND_UP舍入远离零的舍入模式。在丢弃...

  • 使用BigDecimal进行精确计算

    首先我们先来看如下代码示例: 因为计算机是二进制的,我们的浮点型无法精确的用二进制表示(2.4的二进制表示并非就是...

  • 笔记一:DecimalFormat & BigDecimal

    一、DecimalFormat(数字格式化) 例1: 例2: 二、BigDecimal(精确计算) 为什么要用到B...

  • BigDecimal使用(整理)

    应用场景 大多数的商业计算中,一般采用java.math.BigDecimal类来进行精确计算。比如:货币 使用 ...

  • BigDecimal常用方法以及 精确计算

    1.简介 BigDecimal类位于java.math.BigDecimal包下。使用此类可以完成大的小数操作,而...

  • BigDecimal为什么可以精确计算

    为什么浮点数无法精确计算 计算机底层只能用二进制表示数,因此只能精确表示x*2^y类型的数,不能被此形式计算得来的...

  • BigDecimal大精度小数

    BigDecimal用于精度计算 输出结果: 在计算数值的时候,由于浮点数没有办法精确的对二进制进行计算,所以经常...

  • 常见对象BigDecimal的概述

    BigDecimal的概述 由于在运算的时候,float类型和double很容易丢失精度,所以为了能精确表示,计算...

  • 2019-04-10

    浮点数的精确计算用BigDecimal switch-case: 匹配成功会返回当前的case值,若有break则...

  • Java踩坑记系列之BigDecimal

    在java.math包中提供了对大数字的操作类,用于进行高精确计算,如BigInteger,BigDecimal类...

网友评论

    本文标题:Kotlin BigDecimal 精确计算

    本文链接:https://www.haomeiwen.com/subject/tpwgrqtx.html