如何解决java中可能丢失的精度错误

时间:2015-06-15 23:08:31

标签: java scaling

我正在开发一个缩放系统,将数字缩放25%并舍入到最接近的整数,为此,我试图通过将double转换为int来依赖于精度的损失。有没有办法解决这个问题?或者我应该以不同的方式解决这个问题?

public int[] scaleMarks(int[] marks)
{
    double scale = 1.25;
    double temp1;
    int temp2;

    for(int i = 0; i < marks.length; i++)
    {
        temp1 = marks[i] * scale;
        temp2 = marks[i] * scale; //***Loss of precision here***

        if(temp1-temp2>= 0.5)
        {
            temp2++;
        }
        marks[i] = temp2;

    }


    return marks;
}

3 个答案:

答案 0 :(得分:3)

您需要使用Math.round对产品进行舍入,以便可以安全地将其投放到int

marks[i] = (int) Math.round(marks[i] * scale);

答案 1 :(得分:0)

如果你想要圆形到最近而不是截断,你需要使用Math.round。

public class Test {
  public static void main(String[] args) {
    System.out.println((int)0.999999);
    System.out.println(Math.round(0.999999));
  }
}

输出

0
1

答案 2 :(得分:0)

您可以使用Math.round函数来避免它:

(int)Math.round(marks[i] * scale);

编辑:您必须将其投放到int,因为如果您不这样做,结果将是错误的(因为scale它是{{1} })。

我希望它会对你有所帮助!