由于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));
}
}