Java中的浮点数四舍五入到小数点后2位的几种方法

麦洛 等级 1193 0 0

前言

四舍五入到2或3个小数位是我们Java程序员日常开发中肯定会遇到。幸运的是,Java API提供了几种在Java中舍入数字的方法

我们可以使用Math.round()BigDecimalDecimalFormat将Java中的任何浮点数四舍五入到n个位置。我个人更喜欢使用BigDecimal在Java中四舍五入任何数字,因为它具有便捷的API并支持多种舍入模式。 另外,如果您在金融行业工作,最好使用BigDecimal进行货币计算。

舍入数字时要记住的重要事项之一是舍入模式。 舍入模式决定了如何舍弃丢弃的分数,了解诸如HALF DOWNHALF UPHALF EVEN之类的流行舍入模式肯定会有所帮助。

相关知识点

1.Java中的舍入模式

在四舍五入之前要知道的重要一点是四舍五入模式。 通常,程序员认为,如果最后一位小于5,则舍去,如果最后一位大于5,则舍入;

舍入模式决定应如何舍入最低有效位。 BigDecimal类具有定义为整数常量的舍入模式,此模式后来被Java 1.5中的RoundingMode枚举所取代。 以下是一些要记住的重要RoundingMode

RoundingMode.HALF_DOWN:如果两个邻居等距,则向下舍入,例如2.5将舍入为2.0 Java中的浮点数四舍五入到小数点后2位的几种方法 RoundingMode.HALF_UP:如果两个邻居的距离相同则向上舍入,例如2.5将舍入为3.0 Java中的浮点数四舍五入到小数点后2位的几种方法 RoundingMode.HALF_EVEN:如果两个邻居等距,则向偶数舍入,例如2.5将舍入到2.0,而5.5将舍入到6.0

Java中的浮点数四舍五入到小数点后2位的几种方法

还有其他一些舍入模式,例如UPDOWNFLOORCEILING,这也是值得了解的。

2.使用BigDecimal将数字四舍五入到小数点后两位

每当我需要将数字四舍五入到小数点后n位时,我首先想到的是BigDecimalBigDecimal不仅允许您选择RoundingMode,而且使用BigDecimal方法将数字四舍五入到任何小数位都很容易。 这是一个将数字四舍五入到小数点后两位的示例:

package com.milo.base.sort;

import org.junit.Test;

import java.math.BigDecimal;

/**
 * 测试BigDecimal的Api
 * @author milogenius
 * @date 2020-04-14 19:49
 */
public class BigDecimalTest {

    @Test
    public void test1(){
        float number = BigDecimal.valueOf(4.526f)
                .setScale(2, BigDecimal.ROUND_HALF_DOWN)
                .floatValue();
        System.out.println(number);
    }
}
----------------------------------------------
Output:
4.53

setScale()中,您可以指定需要舍入的小数位数,在这里,我们将小数位数设置为2,因为我们将舍入到2位数字。 我们指定舍入模式ROUND_HALF_DOWN,类似于RoundingMode.HALF_DOWN。 您也可以使用RoundingMode.HALF_DOWN来代替BigDecimal.ROUND_HALF_DOWN,但是要注意,从Java 5开始添加了RoundingMode枚举。

3.使用DecimalFormat将数字四舍五入到小数点后两位

如果仅出于显示目的四舍五入数字,则应考虑使用DecimalFormatString``格式方法类。 尽管使用BigDecimal舍入数字没有错,但DecimalFormat似乎是格式化数字的正确类。

这是Java代码,使用Java中的DecimalFormat将数字四舍五入到2位有效数字。

    @Test
    public void test2(){
        DecimalFormat df = new DecimalFormat("#.00");
        float number = Float.valueOf(df.format(4.526f));
        System.out.println(number);
    }

----------------------------------------------
Output:
4.53

#.00用于四舍五入到小数点后两位,如果要四舍五入到小数点后第三位,只需使用#.000#.0000来创建DecimalFormat。 要了解有关格式化数字的更多信息,请参见如何使用DecimalFormat在Java中格式化数字。

4.使用Math.round()在Java中进行舍入运算

Math.round()是Java中舍入数字的经典方法。 尽管它没有提供任何API来指定要舍入的位数,但是通过使用乘法和除法,您可以将其舍入到n或2个小数位。

顺便说一句,这不是Java中舍入数字的首选方法,我更喜欢BigDecimal,但仍然是舍入数字的便捷方法,并且可以在许多情况下使用。 这是在Java中如何使用Math.round()函数将数字四舍五入到2位数字的方法。

    @Test
    public void test3(){
        float rounded = (float) Math.round(4.526f*100)/100;
        System.out.println(rounded);
    }
----------------------------------------------
Output:
4.53

如果需要四舍五入到小数点后五位,我们乘以100来四舍五入,然后乘以100000。顺便说一句,Java的最佳实践是优先使用BigDecimal而不是Math.round()来对Java中的数字进行四舍五入

综合案例

这是一个Java综合案例,它结合了以上3种方法,可以将Java中的任何数字四舍五入到小数点后两位。 您可以将程序更改为最多三位,四位或任意位数。

package com.milo.base.sort;

import java.math.BigDecimal;
import java.text.DecimalFormat;
import java.util.Arrays;


/**
 * 使用三种方式演示java中保留2位小数
 * 包括 BigDecimal,
 * Math.round and DecimalFormat class.
 * @author milogenius
 */

public class RoundingNumbers {


    public static void main(String args[]) {

        //数据
        float[] samples = new float[]{2.123f, 2.125f, 2.127f};


        //使用 Match.round()保留2位小数
        float[] rounded = round(samples);


        System.out.println("开始舍入, numbers: "
                + Arrays.toString(samples));
        System.out.println("结束舍入 : 使用Match.round()方法 "
                + Arrays.toString(rounded));


        //使用BigDecimal保留2位小数
        //我们可以使用不同的舍入模式e.g., HALF_UP, HALF_DOWN,and HALF_EVEN with BigDecimal
        rounded = roundUsingBigDecimal(samples);


        System.out.println("开始舍入,numbers : "
                + Arrays.toString(samples));

        System.out.println("结束舍入, number 使用 BigDecimal: "
                + Arrays.toString(rounded));


        //DecimalFormat Example to round number to 2 digits
        //使用DecimalFormat来保留2位小数
        rounded = roundUsingDecimalFormat(samples);
        System.out.println("开始舍入numbers: "
                + Arrays.toString(samples));
        System.out.println("结束舍入,使用DecimalFormat: "
                + Arrays.toString(rounded));

    }


    /**
     *  使用 Math.round保留2为小数
     * @param numbers
     * @return
     */
    public static float[] round(float[] numbers) {

        float[] round = new float[numbers.length];
        for (int i = 0; i < numbers.length; i++) {
            float number = numbers[i];
            round[i] = (float) Math.round(number * 100) / 100;
        }
        return round;
    }

    /**
     * 使用BigDecimal保留2为小数
     * @param digits
     * @return
     */
    public static float[] roundUsingBigDecimal(float[] digits) {
        float[] result = new float[digits.length];
        for (int i = 0; i < digits.length; i++) {
            float digit = digits[i];
            result[i] = BigDecimal.valueOf(digit)
                    .setScale(2, BigDecimal.ROUND_HALF_DOWN)
                    .floatValue();
        }
        return result;
    }

    /**
     * 使用DecimalFormat保留2为小数
     * @param decimals
     * @return
     */
    public static float[] roundUsingDecimalFormat(float[] decimals) {
        float[] rounded = new float[decimals.length];
        //DecimalFormat to round numbers to 2 decimal place 
        DecimalFormat df = new DecimalFormat("#.00");
        for (int i = 0; i < decimals.length; i++) {
            float decimal = decimals[i];
            rounded[i] = Float.valueOf(df.format(decimal));
        }
        return rounded;
    }
}

总结

综上所述,就是如何在Java中将数字四舍五入到小数点后2位。 我们已经看到3种在Java中舍入数字的方法,例如BigDecimalDecimalFormatMath.round()。 由于便捷的API和对不同舍入模式的支持,BigDecimal看起来是舍入数字的最佳方法。

收藏
评论区

相关推荐

Java中的浮点数四舍五入到小数点后2位的几种方法
前言 四舍五入到2或3个小数位是我们Java程序员日常开发中肯定会遇到。幸运的是,Java API提供了几种在Java中舍入数字的方法 我们可以使用Math.round(),BigDecimal或DecimalFormat将Java中的任何浮点数四舍五入到n个位置。我个人更喜欢使用BigDecimal在Java中四舍五入任何数字,因为它具有便捷的API并
Java BigDecimal使用
1.引言 ----  float和double类型的主要设计目标是为了科学计算和工程计算。他们执行二进制浮点运算,这是为了在广域数值范围上提供较为精确的快速近似计算而精心设计的。然而,它们没有提供完全精确的结果,所以不应该被用于要求精确结果的场合。但是,商业计算往往要求结果精确,这时候BigDecimal就派上大用场啦。 测试用例: publi
Java 的BigDecimal
原文:http://blog.csdn.net/diyu122222/article/details/76887382 * decimal > decimal(18,0) 18是定点精度,0是小数位数。 > > decimal(a,b) a指定指定小数点左边和右边可以存储的十进制数字的最大个数,最大精度38。 > > b指定小数点右边可以存储的十
Java中BigDecimal的8种舍入模式
java.math.BigDecimal ==================== 不可变的、任意精度的有符号十进制数。BigDecimal 由任意精度的整数非标度值和32位的整数标度(scale)组成。 如果为零或正数,则标度是小数点后的位数。如果为负数,则将该数的非标度值乘以10的负scale次幂。 因此,BigDecimal表示的数值是(unsc
Java中的BigDecimal类和int和Integer总结
### 前言 我们都知道浮点型变量在进行计算的时候会出现丢失精度的问题。如下一段代码: System.out.println(0.05 + 0.01); System.out.println(1.0 - 0.42); System.out.println(4.015 * 100); System.out.println(1
Java的BigDecimal容易出现的坑
BigDecimal一般是用来做要求比较高的精准计算的。前几天在使用的时候遇到一个大坑,记录下。 这个问题产生是使用BigDecimal做除法(divide)运算,这个类的divide方法存在三个常用的构造函数。 `BigDecimal` `**divide**(BigDecimal divisor)`            Returns a `
Java:利用BigDecimal类巧妙处理Double类型精度丢失
本篇要点 ==== * 简单描述浮点数十进制转二进制精度丢失的原因。 * 介绍几种创建BigDecimal方式的区别。 * 整理了高精度计算的工具类。 * 学习了阿里巴巴Java开发手册关于BigDecimal比较相等的规定。 **经典问题:浮点数精度丢失** ================ 精度丢失的问题是在其他计算机语言中也都会出
java 大数基本操作
导言:   计算机中数字的表示范围是有一定的限制的,像Java中,常用的数据类型,如int、double等数据类型表示的范围都是有限的,当我们要计算的数字,其位数达到成百上千时,这些数据类型无法满足我们的需求,C语言中我们可以使用数组来储存位数,再对两个数组进行相应的运算;Java中为了处理大整数的运算,提供了一种数据类型:BigInteger,BigDe
java 泛型中遇到的问题
首先说下什么是定义带类型参数的泛型例如:  public static <T, S extends T> void Test<T t,S s> {      Systen.out.println(t.getClass().getName());      Systen.out.println(s.getClass().getName
java.math.BigDecimal类的用法
在java中提供了大数字的操作类,即java.math.BinInteger类和java.math.BigDecimal类。这两个类用于高精度计 算,其中BigInteger类是针对大整数的处理类,而BigDecimal类则是针对大小数的处理类。下边我们介绍BigDecimal类: BigDecimal的实现利用到了BigInteger,不同的是Big
java中经常问到的面试题
1、面向对象编程的三大特性是什么? ================= (1).继承: 继承是一种联结类的层次模型,并且允许和鼓励类的重用,它提供了一种明确表述共性的方法。对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继 承了原始类的特性,新类称为原始类的派生类(子类),而原始类称为新类的基类(父类)。派生类可以从它的基类那里继承方法和实例
java浮点型精度丢失浅析
java浮点型数值在运算中会出现精度损失的情况,在业务要求比较高比如交易等场景,一般使用BigDecimal来解决精度丢失的情况。最近一个同事在使用BigDecimal时仍然出现了精度损失,简略记录一下 ### 测试用例 代码如下 @Test public void fd() { double abc =
BigDecimal与Long、int之间的相互转换
在实际开发过程中BigDecimal是一个经常用到的数据类型,它和int 、Long之间可以相互转换。 转换关系如下代码展示: ----------- 一、int 转换成 BigDecimal 数据类型 //int 转换成 bigDecimal类型 public static BigDecimal intToBigDecim
BigDecimal去除末尾多余的0
Java有自带的 stripTrailingZeros() 方法用于去除末尾多余的0 BigDecimal num = new BigDecimal("100.000"); BigDecimal numNoEndZero = num.stripTrailingZeros(); //numNoEndZero :1E+2 Sys
BigDecimal的四则运算及小数位数格式
一、加法 BigDecimal b1 = new BigDecimal("20");BigDecimal b2 = new BigDecimal("30");BigDecimal add = b1.add(b2);System.out.println(add);打印结果:50 二、减法 BigDecimal b1 = new BigDe