高精度计算,凡涉及到金额的务必使用该类型

  • 推荐使用BigDecimal(String)构造BigDecimal对象
  • Decimal都是不可变的(immutable)的,在进行每一步运算时,都会产生一个新的对象,所以在做加减乘除运算时千万要保存操作后的值。
  • 当divide不能整除的时候,要设置精度和舍入模式,否则抛异常
  • compareTo和equals都可用于比较BigDecimal,但equals会比较精度,例如0.00和0使用compareTo为0相等,使用equals不想等,基本上都使用compareTo
  • 将int或double转为BigDecimal使用valueOf避免精度问题(调用Double的toString)
  • 对于0,1,10可以直接使用常量BigDecimal.ZERO,ONE,TWO
1、常用API
  • add(BigDecimal) BigDecimal对象中的值相加,然后返回这个对象。
  • subtract(BigDecimal) BigDecimal对象中的值相减,然后返回这个对象。
  • multiply(BigDecimal) BigDecimal对象中的值相乘,然后返回这个对象。
  • divide(BigDecimal[,保留小数点后几位小数,舍入模式]) BigDecimal对象中的值相除,然后返回这个对象。
  • 其他:toString()、intValue()、doubleValue()、compareTo(b)、abs()、max(b)、min(b)、negate()、pow(sup)
2、小数保留

setScale(保留小数点后几位小数[,舍入模式])

舍入模式(以下为BigDecimal常量,已弃用,使用RoundingMode代替)
  • ROUND_HALF_UP //四舍五入,1.55=1.6
  • ROUND_HALF_DOWN //五舍四入,1.55=1.5,与上则的区别在中间位置的取舍
  • ROUND_CEILING / 向正无限大方向舍入的舍入 ,1.55=1.6,-1.55=-1.5
  • ROUND_FLOOR // 向负无限大方向舍入的舍入模式 ,1.55=1.5,-1.55=-1.6
  • ROUND_UP //远离零方向舍入的舍入模式, 1.55=1.6,-1.55=-1.6
  • ROUND_DOWN //向零方向舍入的舍入模式 ,1.55=1.5,-1.55=-1.5
  • ROUND_HALF_EVEN //向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,如果保留位数是奇数,使用
  • ROUND_UNNECESSARY //默认,计算结果是精确的,不需要舍入模式,但必须保证小数位数大于结果的小数位
RoundingMode
  • HALF_UP // 四色五入,等同于BigDecimal.ROUND_HALF_UP
  • FLOOR // 向下取,5.559 = 5.55,等同于BigDecimal.ROUND_FLOOR
  • CEILING // 想上去 ,5.551 = 5.56,等同于BigDecimal.ROUND_CEILING
Logo

CSDN联合极客时间,共同打造面向开发者的精品内容学习社区,助力成长!

更多推荐