`

BigDecimal 运用小数

 
阅读更多

BigDecimal.setScale()方法用于格式化小数点

setScale(1)表示保留一位小数,默认用四舍五入方式 

setScale(1,BigDecimal.ROUND_DOWN)直接删除多余的小数位,如2.35会变成2.3 

setScale(1,BigDecimal.ROUND_UP)进位处理,2.35变成2.4 

setScale(1,BigDecimal.ROUND_HALF_UP)四舍五入,2.35变成2.4

setScaler(1,BigDecimal.ROUND_HALF_DOWN)四舍五入,2.35变成2.3,如果是5则向下舍

 

 

注释:

1:

scale指的是你小数点后的位数。比如123.456则score就是3.

score()就是BigDecimal类中的方法啊。

比如:BigDecimal b = new BigDecimal("123.456");

b.scale(),返回的就是3.

2:

roundingMode是小数的保留模式。它们都是BigDecimal中的常量字段,有很多种。

比如:BigDecimal.ROUND_HALF_UP表示的就是4舍5入。

3:

pubilc BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)

的意思是说:我用一个BigDecimal对象除以divisor后的结果,并且要求这个结果保留有scale个小数位,roundingMode表示的就是保留模式是什么,是四舍五入啊还是其它的,你可以自己选!

4:对于一般add、subtract、multiply方法的小数位格式化如下:

BigDecimal mData = new BigDecimal("9.655").setScale(2, BigDecimal.ROUND_HALF_UP);

        System.out.println("mData=" + mData);

 

----结果:----- mData=9.66

		String yearRate ="0.13999999999999999999";
		System.out.println(yearRate);
		BigDecimal decimal = new BigDecimal(yearRate).multiply(new BigDecimal(100));
		yearRate = decimal.setScale(2, BigDecimal.ROUND_DOWN).toString();
		System.out.println(yearRate);

 ----结果:

0.13999999999999999999

 

13.99

 

 

 

static BigDecimal ONE 

          值为 1,标度为 0。 

static int ROUND_CEILING 

          接近正无穷大的舍入模式。 

static int ROUND_DOWN 

          接近零的舍入模式。 

static int ROUND_FLOOR 

          接近负无穷大的舍入模式。 

static int ROUND_HALF_DOWN 

          向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为上舍入的舍入模式。 

static int ROUND_HALF_EVEN 

          向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。 

static int ROUND_HALF_UP 

          向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。 

static int ROUND_UNNECESSARY 

          断言请求的操作具有精确的结果,因此不需要舍入。 

static int ROUND_UP 

          舍入远离零的舍入模式。 

static BigDecimal TEN 

          值为 10,标度为 0。 

static BigDecimal ZERO 

          值为 0,标度为 0。

 

 

分享到:
评论

相关推荐

    java BigDecimal操作

    总的来说,理解和熟练运用BigDecimal是每个Java开发者必备的技能之一,特别是在处理货币计算、财务计算等场景时,能够避免因为浮点数精度问题导致的错误。在使用BigDecimal时,一定要注意其性能开销,因为它比基本的...

    Java中BigDecimal类的简单用法

    在实际开发中,BigDecimal类提供了许多其他的方法,如add()用于加法,divide()用于除法,compare()用于比较两个BigDecimal对象的大小,scale()和precision()用于获取或设置小数位数等。在进行商业计算时,尤其是涉及...

    定点小数的运算器,有加减等

    在IT领域,尤其是在计算机系统设计...JAVA提供了强大的工具来支持这些运算,使得开发者能够在各种计算任务中灵活运用定点小数。了解和掌握定点小数的运算原理和JAVA中的实现,对于提升程序的效率和准确性具有重要意义。

    @JsonFormat的使用jackson-annotations

    在这个例子中,`shape = JsonFormat.Shape.STRING`确保了价格始终以字符串形式输出,`pattern = "#,###.##"`则使用千分符分隔并保留两位小数。 Jackson库的这三个核心组件协同工作,提供了一套完整的解决方案。`...

    java保留小数的四种实现方法

    本文将详细介绍四种在Java中保留小数的方法,分别是使用`BigDecimal`、`DecimalFormat`、`String.format()`以及`NumberFormat`类。 1. **使用BigDecimal进行四舍五入** `BigDecimal` 类提供了一个精确的浮点数运算...

    java 四舍五入 需要的朋友看看

    System.out.println("保留两位小数(3.856)=" + new BigDecimal(i).setScale(2, BigDecimal.ROUND_HALF_UP)); } } ``` 上述代码中,`setScale(0, BigDecimal.ROUND_HALF_UP)`会将3.856四舍五入到最接近的整数,...

    javaInteger大数据运算.pdf

    在Java编程语言中,处理大数据和高精度计算是一项常见的任务,特别是在金融、科学计算或数据分析等领域。...通过了解和熟练运用`BigInteger`和`BigDecimal`,开发者能够编写出更稳定且准确的程序。

    Java_BigDecimalInterest:使用 BigDecimal 计算复利的简单程序。 摘自“Java How To Program, 10e, Early Objects”——第 8 章

    在Java编程中,BigDecimal类是...这个简单的复利计算程序是一个很好的实践案例,可以帮助你更好地理解和运用BigDecimal类。通过实践和调试这个程序,你不仅可以学习到BigDecimal的用法,还能巩固对复利计算原理的理解。

    java 取整

    理解并熟练运用这些方法对于编写高效且准确的代码至关重要。在实际编程中,选择哪种取整方式取决于具体的应用场景和对结果精度的要求。务必注意数据类型的转换,避免因浮点数到整数的截断导致不必要的数据丢失。

    超强常用的正则表达式2009

    正则表达式(Regular Expression,简称regex)是用于匹配字符串的一种模式,广泛应用于文本处理、数据验证、搜索和替换等场景。...通过不断地实践和学习,我们可以更灵活地运用这些工具,解决各种复杂的文本处理问题。

    jsp中百分比表示方法

    接着将结果转换为`BigDecimal`对象,并使用`setScale()`方法设置保留两位小数,并指定四舍五入规则`BigDecimal.ROUND_HALF_UP`。 #### 2. 使用`DecimalFormat`进行格式化输出 除了`BigDecimal`之外,还可以使用`...

    数字格式化类与大数处理利用案例轻松学习Java语言PPT学习教案.pptx

    `BigInteger`和`BigDecimal`的主要区别在于它们处理的数据类型:`BigInteger`适用于大整数,而`BigDecimal`适用于需要高精度的小数。在实际应用中,应根据需求选择合适的数据类型。 使用`DecimalFormat`格式化数字...

    JavaScript 精确计算(2)

    在JavaScript编程语言中,精确计算是一项重要的需求,特别是在金融、科学计算或任何需要...通过深入理解和运用这些知识点,开发者可以有效地在JavaScript环境中实现高精度的数学计算,避免因浮点数不精确而导致的问题。

    API的使用、数组的高级操作

    BigDecimal提供了加减乘除的方法,并且在除法中可以指定保留的小数位数和舍入模式。 数组是Java中的基础数据结构,对于有序数组,我们可以使用二分查找算法提高查找效率。二分查找的前提是数组已经排序,它通过不断...

    计算器--简单的加减乘除

    1. 使用大数库:许多编程语言提供了大数库,如Python的`decimal`模块,Java的`BigDecimal`类,这些库专门设计用于进行高精度计算,避免浮点数误差。它们以字符串或其他非二进制形式存储数字,确保在加减乘除操作中的...

    20151910042-刘鹏-MC实验01-编程平台实验1

    2. **Java的大整数类库**:实验的选做部分涉及到Java的`BigInteger`和`BigDecimal`类,这两个类分别用于处理大整数和任意精度的小数。`BigInteger`提供了比Java内置的`int`和`long`类型更大范围的整数操作,而`...

    java基础--4.常用类-6.数字

    在处理大整数或者高精度浮点数时,Java提供了BigInteger和BigDecimal类。这两个类允许我们进行任意精度的算术运算,适合于需要精确计算的场景。 总之,Java中的数字处理涵盖了许多方面,从基本的数据类型到复杂的...

    Java基础学习14.pdf

    在Java编程语言中,基础知识是每个开发者都需要扎实掌握的关键部分。本资源主要涵盖了Java的基础学习内容,特别是关于Object类、数字格式化、大数据...只有全面理解并熟练运用这些知识,才能成为一名合格的Java开发者。

    阿里开发手册

    例如,0.1在二进制表示中是一个无限循环小数,使用double类型构造时会发生舍入,导致精度损失。正确的做法是使用字符串构造BigDecimal对象,字符串表示可以确保精度不会丢失。 三、为什么禁止使用Apache BeanUtils...

Global site tag (gtag.js) - Google Analytics