MathUtil - 四舍五入

由于Java的float和double数值,在进行计算时,无法保证数据的精度,四舍五入的需要就迫切需要。 当然,用long再除以100也不错,但比较麻烦。 或采用BigDecimal也将会是一个比较好的选择,但其不可变的特性又使得计算中长生大量的垃圾对象。如果程序中需要进行计算,有想保持精度,那就使用一个四舍五入来处理吧。

 

这是一个个人编写的用于数值计算后四舍五入的小程序。

 

public class MathUtil
{
  public static int devide(int x, int y)
  {
    float f = x;
    return Math.round(f / y);
  }

  public static long devide(long x, long y)
  {
    double d = x;
    return Math.round(d / y);
  }

  public static float round(float f, int bit)
  {
    float p = (float)pow(bit);
    return (Math.round(f * p) / p);
  }

  public static double round(double d, int bit)
  {
    double p = pow(bit);
    return (Math.round(d * p) / p);
  }

  private static long pow(int bit)
  {
    return Math.round(Math.pow(10.0D, bit));
  }
}
 

 

你可能感兴趣的:(F#)