Java: Check if two double values match on specific no of decimal places

前端 未结 5 1130
旧巷少年郎
旧巷少年郎 2020-12-19 02:42

Comparing those two values shall result in a \"true\":

53.9173333333333  53.9173
相关标签:
5条回答
  • 2020-12-19 02:48

    here is the simple example if you still need this :)

    public static boolean areEqualByThreeDecimalPlaces(double a, double b) {
    
        a = a * 1000;
    
        b = b * 1000;
    
        int a1 = (int) a;
    
        int b1 = (int) b;
    
        if (a1 == b1) {
            System.out.println("it works");
            return true;
        }
    
        else
            System.out.println("it doesn't work");
        return false;
    
    0 讨论(0)
  • 2020-12-19 02:53

    Apache commons has this: org.apache.commons.math3.util.Precision equals(double x, double y, double eps)

    epsilon would be the distance you would allow. Looks like yours would be 1e-5?

    The source-code of this method looks like it uses Math.abs as suggested in other answers.

    0 讨论(0)
  • 2020-12-19 02:55

    Thanks. I did it this way:

    double lon = 23.567889;
    BigDecimal bdLon = new BigDecimal(lon);
    bdLon = bdLon.setScale(4, BigDecimal.ROUND_HALF_UP);
    
    System.out.println(bdLon.doubleValue());
    
    0 讨论(0)
  • 2020-12-19 03:01

    Naively:

    if(Math.abs(a-b) < 0.0001)
    

    However, that's not going to work correctly for all values. It's actually impossible to get it to work as long as you're using double, because double is implemented as binary fractons and does not even have decimal places.

    You'll have to convert your values to String or BigDecimal to make meaningful tests about their decimal places.

    You may want to read the Floating-Point Guide to improve your understanding of how floating point values work.

    0 讨论(0)
  • 2020-12-19 03:05

    If you want a = 1.00001 and b = 0.99999 be identified as equal:

    return Math.abs(a - b) < 1e-4;
    

    Otherwise, if you want a = 1.00010 and b = 1.00019 be identified as equal, and both a and b are positive and not huge:

    return Math.floor(a * 10000) == Math.floor(b * 10000);
    // compare by == is fine here because both sides are integral values.
    // double can represent integral values below 2**53 exactly.
    

    Otherwise, use the truncate method as shown in Are there any functions for truncating a double in java?:

    BigDecimal aa = new BigDecimal(a);
    BigDecimal bb = new BigDecimal(b);
    aa = aa.setScale(4, BigDecimal.ROUND_DOWN);
    bb = bb.setScale(4, BigDecimal.ROUND_DOWN);
    return aa.equals(bb);
    
    0 讨论(0)
提交回复
热议问题