Java BigDecimal Rounding Mode

UP          往绝对值大了取

DOWN        往绝对值小了取

CEILING       往值大了取

FLOOR        往值小了取

HALF_UP      不管正负,四舍五入

HALF_DOWN  不管正负,五舍六入

HALF_EVEN    整数部分为奇数:四舍五入; 整数部分为偶数:五舍六入

UNNECESSARY   小数不为零直接报错。。。

时间: 2024-10-29 21:56:15

Java BigDecimal Rounding Mode的相关文章

java bigDecimal and double

Java BigDecimal和double BigDecimal是Java中用来表示任意精确浮点数运算的类,在BigDecimal中,使用unscaledValue × 10-scale来表示一个浮点数.其中,unscaledValue是一个BigInteger,scale是一个int.从这个表示方法来看,BigDecimal只能标识有限小数,不过可以表示的数据范围远远大于double,在实际应用中基本足够了. 下面提一下两个精度问题: 问题一:BigDecimal的精度问题(StackOve

Java BigDecimal类

1 package demo04; 2 3 import java.math.BigDecimal; 4 5 //double和float类型在运算中很容易丢失精度,造成数据的不准确性,BigDecimal类可以实现浮点数据的高精度运算 6 public class BigDecimalDemo { 7 public static void main(String[] args) { 8 BigDecimal b1 = new BigDecimal("0.09"); 9 BigDeci

java BigDecimal工具类

package com.core.calculate; import java.math.BigDecimal; import java.text.DecimalFormat; /** * Created by tangxin on 2017/1/6 0006. * 如有问题,欢迎提出更正 */ public class BigNum { public static final String BIG_NUM_FMT_COMMA = "#,###,###,###,###,###,##0.00&qu

java BigDecimal

1.引言 借用<Effactive Java>这本书中的话,float和double类型的主要设计目标是为了科学计算和工程计算.他们执行二进制浮点运算,这是为了在广域数值范围上提供较为精确的快速近似计算而精心设计的.然而,它们没有提供完全精确的结果,所以不应该被用于要求精确结果的场合.但是,商业计算往往要求结果精确,这时候BigDecimal就派上大用场啦. 2.BigDecimal简介 BigDecimal 由任意精度的整数非标度值 和32 位的整数标度 (scale) 组成.如果为零或正数

Java BigDecimal和double

BigDecimal类 对于不需要任何准确计算精度的数字可以直接使用float或double,但是如果需要精确计算的结果,则必须使用BigDecimal类,而且使用BigDecimal类也可以进行大数的操作.BigDecimal类的常用方法如表所示. BigDecimal类的常用方法 序号 方    法 类型 描    述 1 public BigDecimal(double val) 构造 将double表示形式转换 为BigDecimal 2 public BigDecimal(int va

JAVA BigDecimal 小数点处理

保留两位小数{ 方法一:{ double   c=3.154215; Java.text.DecimalFormat myformat=new java.text.DecimalFormat("0.00"); String str = myformat.format(c);   } 方式二:{ java.text.DecimalFormat   df   =new   java.text.DecimalFormat("#.00");   df.format(你要格式

java BigDecimal的使用和四舍五入及格式规范(精准数据)

• Java中的简单浮点数类型float和double不能够进行运算.不光是Java,在其它很多编程语言中也有这样的问题. 如果我们编译运行下面这个程序会看到什么? public   class  Test  {      public   static   void  main(String args[])  {                 System.out.println(0.05 + 0.01);         System.out.println(1.0 - 0.42);   

Java BigDecimal 转换,除法陷阱(转)

源地址:   http://blog.csdn.net/niannian_315/article/details/24354251 今天在用BigDecimal“出现费解”现象,以前虽然知道要避免用,但没研究过.借此机会,查证一下分享给大家参详参详. 在Java中经常可以用到double转BigDecimal,也经常进行除法运算,但是以下用法需要特别小心了. Java代码   package com.ccxe.number; import java.math.BigDecimal; import

Java BigDecimal详解

1.引言 float和double类型的主要设计目标是为了科学计算和工程计算.他们执行二进制浮点运算,这是为了在广域数值范围上提供较为精确的快速近似计算而精心设计的.然而,它们没有提供完全精确的结果,所以不应该被用于要求精确结果的场合.但是,商业计算往往要求结果精确,这时候BigDecimal就派上大用场啦. 先看下面代码 public static void main(String[] args) { System.out.println(0.2 + 0.1); System.out.prin