计算机中浮点数的表示(java四舍五入方法表达式)

前言四舍五入到2或3个小数位是我们Java程序员日常开发中肯定会遇到。幸运的是,JavaAPI提供了几种在Java中舍入数字的方法我们可以使用Math.round(),BigDecimal或Deci

前言

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

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

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

相关知识点

1.Java中的舍入模式

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

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

RoundingMode.HALF_DOWN:如果两个邻居等距,则向下舍入,例如2.5将舍入为2.0

计算机中浮点数的表示(java四舍五入方法表达式)

RoundingMode.HALF_UP:如果两个邻居的距离相同则向上舍入,例如2.5将舍入为3.0

计算机中浮点数的表示(java四舍五入方法表达式)

RoundingMode.HALF_EVEN:如果两个邻居等距,则向偶数舍入,例如2.5将舍入到2.0,而5.5将舍入到6.0

计算机中浮点数的表示(java四舍五入方法表达式)

还有其他一些舍入模式,例如UP,DOWN,FLOOR和CEILING,这也是值得了解的。

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

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

  1. <span>package</span> com.milo.base.sort;<span>import</span> org.junit.Test;<span>import</span> java.math.BigDecimal;<span>/** * 测试BigDecimal的Api * <span>@author</span> milogenius * <span>@date</span> 2020-04-14 19:49 */</span><span>public</span> <span><span>class</span> <span>BigDecimalTest</span> </span>{    <span>@Test</span>    <span><span>public</span> <span>void</span> <span>test1</span><span>()</span></span>{        <span>float</span> number = BigDecimal.valueOf(<span>4.526f</span>)                .setScale(<span>2</span>, BigDecimal.ROUND_HALF_DOWN)                .floatValue();        System.out.println(number);    }}----------------------------------------------Output:<span>4.53</span>

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

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

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

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

  1.     @<span>Test    <span>public</span> <span>void</span> <span>test2</span>()</span>{        DecimalFormat df = <span>new</span> DecimalFormat(<span>\"#.00\"</span>);        <span>float</span> number = Float.valueOf(df.format(<span>4.526f</span>));        System.<span>out</span>.println(number);    }----------------------------------------------Output:<span>4.53</span>

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

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

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

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

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

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

综合案例

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

  1. package com.milo.<span>base</span>.sort;import java.math.BigDecimal;import java.text.DecimalFormat;import java.util.Arrays;<span>/** * 使用三种方式演示java中保留2位小数 * 包括 BigDecimal, * Math.round and DecimalFormat class. * @author milogenius */</span><span>public</span> <span>class</span> <span>RoundingNumbers</span> {    <span><span>public</span> <span>static</span> <span>void</span> <span>m<strong>ai</strong>n</span>(<span>String args[]</span>)</span> {        <span>//数据</span>        <span>float</span>[] samples = <span>new</span> <span>float</span>[]{<span>2.123f</span>, <span>2.125f</span>, <span>2.127f</span>};        <span>//使用 Match.round()保留2位小数</span>        <span>float</span>[] rounded = round(samples);        System.<span>out</span>.println(<span>\"开始舍入, numbers: \"</span>                + Arrays.toString(samples));        System.<span>out</span>.println(<span>\"结束舍入 : 使用Match.round()方法 \"</span>                + Arrays.toString(rounded));        <span>//使用BigDecimal保留2位小数</span>        <span>//我们可以使用不同的舍入模式e.g., HALF_UP, HALF_DOWN,and HALF_EVEN with BigDecimal</span>        rounded = roundUsingBigDecimal(samples);        System.<span>out</span>.println(<span>\"开始舍入,numbers : \"</span>                + Arrays.toString(samples));        System.<span>out</span>.println(<span>\"结束舍入, number 使用 BigDecimal: \"</span>                + Arrays.toString(rounded));        <span>//DecimalFormat Example to round number to 2 digits</span>        <span>//使用DecimalFormat来保留2位小数</span>        rounded = roundUsingDecimalFormat(samples);        System.<span>out</span>.println(<span>\"开始舍入numbers: \"</span>                + Arrays.toString(samples));        System.<span>out</span>.println(<span>\"结束舍入,使用DecimalFormat: \"</span>                + Arrays.toString(rounded));    }    <span>/**     *  使用 Math.round保留2为小数     * @param numbers     * @return     */</span>    <span><span>public</span> <span>static</span> <span>float</span>[] <span>round</span>(<span><span>float</span>[] numbers</span>)</span> {        <span>float</span>[] round = <span>new</span> <span>float</span>[numbers.length];        <span>for</span> (<span>int</span> i = <span>0</span>; i < numbers.length; i++) {            <span>float</span> number = numbers[i];            round[i] = (<span>float</span>) Math.round(number * <span>100</span>) / <span>100</span>;        }        <span>return</span> round;    }    <span>/**     * 使用BigDecimal保留2为小数     * @param digits     * @return     */</span>    <span><span>public</span> <span>static</span> <span>float</span>[] <span>roundUsingBigDecimal</span>(<span><span>float</span>[] digits</span>)</span> {        <span>float</span>[] result = <span>new</span> <span>float</span>[digits.length];        <span>for</span> (<span>int</span> i = <span>0</span>; i < digits.length; i++) {            <span>float</span> digit = digits[i];            result[i] = BigDecimal.valueOf(digit)                    .setScale(<span>2</span>, BigDecimal.ROUND_HALF_DOWN)                    .floatValue();        }        <span>return</span> result;    }    <span>/**     * 使用DecimalFormat保留2为小数     * @param decimals     * @return     */</span>    <span><span>public</span> <span>static</span> <span>float</span>[] <span>roundUsingDecimalFormat</span>(<span><span>float</span>[] decimals</span>)</span> {        <span>float</span>[] rounded = <span>new</span> <span>float</span>[decimals.length];        <span>//DecimalFormat to round numbers to 2 decimal place </span>        DecimalFormat df = <span>new</span> DecimalFormat(<span>\"#.00\"</span>);        <span>for</span> (<span>int</span> i = <span>0</span>; i < decimals.length; i++) {            <span>float</span> <span>decimal</span> = decimals[i];            rounded[i] = Float.valueOf(df.format(<span>decimal</span>));        }        <span>return</span> rounded;    }}

总结(求转发关注)

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

本站部分文章来自网络或用户投稿,如无特殊说明或标注,均为本站原创发布。涉及资源下载的,本站旨在共享仅供大家学习与参考,如您想商用请获取官网版权,如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
投稿

罗技鼠标双击简单修复(鼠标连点怎么修复)

2023-11-18 12:58:11

投稿

电脑打开应用的提醒弹窗(电脑弹窗怎么设置开启)

2023-11-18 12:58:50

搜索