Java floating point math - (conversion for feet/meters)

前端 未结 5 476
爱一瞬间的悲伤
爱一瞬间的悲伤 2021-01-20 16:36

Pretty basic question I think - I\'m performing this function:

private double convertMetersToFeet(double meters)
{
  //function converts Feet to Meters.
             


        
相关标签:
5条回答
  • 2021-01-20 16:59

    If it is not for printing you should not care about the error. 337.36080000000004 is just as correct as 337.3608 since you only have 5 significant digits in the factor and only 3 in the test input. (And I certainly hope that the answer your method gave was 331 and not 337)

    However, this line fetched from another question seems to do the trick as well.

    double toFeet = ((int)(meters*3.2808*10000))/10000.0;
    

    The only problem is that is overflows a lot faster.

    0 讨论(0)
  • 2021-01-20 17:00

    Use java.math.BigDecimal for decimal arithmetic.

    0 讨论(0)
  • 2021-01-20 17:04

    You can use a NumberFormat instance.

    NumberFormat nf = NumberFormat.getInstance(Locale.UK);
    nf.setMinimumFractionDigits(4);
    nf.setMaximumFractionDigits(4);
    System.out.println(nf.format(feet));
    

    Or you can use DecimalFormat.

    DecimalFormat df = new DecimalFormat("0.0000");
    System.out.println(df.format(feet));
    

    The latter (DecimalFormat), is to be used when you explicitly want to state the format and the former (NumberFormat), when want localized settings.

    For four consistent fractional figures, there is no need to drag in BigDecimal, if your aren't working with really long distances.

    0 讨论(0)
  • 2021-01-20 17:06

    I'm answering my own question for posterity's sake. I used the DecimalFormat answer above, but the answers failed to take into account the return type of the method.

    Here's the finished code:

      private double convertMetersToFeet(double meters)
    {
      //function converts Feet to Meters.
          double toFeet = meters;
          toFeet = meters*3.2808;  // official conversion rate of Meters to Feet
          String formattedNumber = new DecimalFormat("0.0000").format(toFeet); //return with 4 decimal places
          double d = Double.valueOf(formattedNumber.trim()).doubleValue();
          return d;
    }
    
    0 讨论(0)
  • 2021-01-20 17:12

    If you need precise calculations, use BigDecimal instead of float. If you just want to truncate on printing, use DecimalFormat.

    DecimalFormat df = new DecimalFormat ("0.00");
    System.out.println(df.format(convertMetersToFeet(101)));
    
    0 讨论(0)
提交回复
热议问题