使用Math.round舍入到一个小数位?

时间:2014-03-05 01:35:06

标签: java decimal rounding

我有这两个变量

double num = 540.512
double sum = 1978.8

然后我做了这个表达

double total = Math.round((num/ sum * 100) * 10) / 10;

但我最终得到了27.0。

事实上我还有很多其他变量,当我在表达式中使用它们时,我总是在第十个位置得到一个。

9 个答案:

答案 0 :(得分:74)

我刚才创建的有用方法......

private static double round (double value, int precision) {
    int scale = (int) Math.pow(10, precision);
    return (double) Math.round(value * scale) / scale;
}

答案 1 :(得分:21)

试试这个

例如

DecimalFormat df = new DecimalFormat("#.##");
df.format(55.544545);

输出:

55.54

答案 2 :(得分:15)

Math.round method returns a long(如果传入int,则为float),Java的整数除法是罪魁祸首。将其转换回double,或在除以double时使用10字面值。之一:

double total = (double) Math.round((num / sum * 100) * 10) / 10;

double total = Math.round((num / sum * 100) * 10) / 10.0;

然后你应该

27.3

答案 3 :(得分:13)

    Double toBeTruncated = new Double("2.25");

    Double truncatedDouble=new BigDecimal(toBeTruncated ).setScale(1, BigDecimal.ROUND_HALF_UP).doubleValue();

它将返回2.3

答案 4 :(得分:10)

如果您需要更频繁地进行此类操作,那么找到合适的库而不是自己实现它可能会更方便。

以下是使用Precision,使用Functions的Colt和使用Utils的Weka从Apache Commons Math解决问题的单行:

double value = 540.512 / 1978.8 * 100;
// Apache commons math
double rounded1 = Precision.round(value, 1);
double rounded2 = Precision.round(value, 1, BigDecimal.ROUND_HALF_UP);
// Colt
double rounded3 = Functions.round(0.1).apply(value)
// Weka
double rounded4 = Utils.roundDouble(value, 1)

Maven依赖项:

<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-math3</artifactId>
    <version>3.5</version>
</dependency>

<dependency>
    <groupId>colt</groupId>
    <artifactId>colt</artifactId>
    <version>1.2.0</version>
</dependency>

<dependency>
    <groupId>nz.ac.waikato.cms.weka</groupId>
    <artifactId>weka-stable</artifactId>
    <version>3.6.12</version>
</dependency>

答案 5 :(得分:3)

在我看来,一个更加可读的简洁替代方案,由于double和String之间的转换,可能效率低一点:

double num = 540.512;
double sum = 1978.8;

// NOTE: This does take care of rounding
String str = String.format("%.1f", (num/sum) * 100.0); 

如果您希望答案为双倍,您当然可以将其转换回来:

double ans = Double.parseDouble(str);

答案 6 :(得分:3)

Double number = new Double("5.25");
Double tDouble = 
  new BigDecimal(number).setScale(1, BigDecimal.ROUND_HALF_UP).doubleValue();

这将返回它将返回5.3

答案 7 :(得分:2)

你的方法是对的,所有你要做的就是在数十之后添加一个.0它会解决你的问题!

5.3

输出结果为:

{{1}}

答案 8 :(得分:2)

DecimalFormat decimalFormat = new DecimalFormat(".#");
String result = decimalFormat.format(12.763);                // -->  12.7