日期:2014-05-20  浏览次数:20804 次

double类型的问题
比如:   double   a   =0.0;
              a   =   100000000.0;
              double   b   =(a/10000000.0)*10000000.0;
              if(a==b)
                {               AAAAAAAAAAAAAAAAAAAAAAAAAAAAAA           }
              else   {     BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB           }  
这样在什么情况会执行BBBBBBBBBBBBBBBBBBBBBBBBBBBBBB

再如:要解决1.55555   这个数     把小数点后第3位开始按四舍五入的方法舍去

应该怎么实现??

在线等待答案。。。

------解决方案--------------------
TO:
bao110908(长牙了,好痛)
你说的这种方法并不完全正确,因为Math.round()的默认的 RoundingMode是 HALF_DOWN,所以当输入是4.15时,得到结果是4.1而不是4.2。
因此这种方法不能做到精确的四舍五入,不能满足要求。

可以使用BigDecimal(String)构造BigDecimal对象进行运算,保证数据的精确计算。

这里提供了一个工具类,定义浮点数的加、减、乘、除和四舍五入等运算方法,以供参考。
源文件MathExtend.java:
import java.math.BigDecimal;
public class MathExtend
{
//默认除法运算精度
private static final int DEFAULT_DIV_SCALE = 10;
/**
* 提供精确的加法运算。
* @param v1
* @param v2
* @return 两个参数的和
*/
public static double add(double v1, double v2)
{
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.add(b2).doubleValue();
}
/**
* 提供精确的加法运算
* @param v1
* @param v2
* @return 两个参数数学加和,以字符串格式返回
*/
public static String add(String v1, String v2)
{
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return b1.add(b2).toString();
}
/**
* 提供精确的减法运算。
* @param v1
* @param v2
* @return 两个参数的差
*/
public static double subtract(double v1, double v2)
{
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.subtract(b2).doubleValue();
}
/**
* 提供精确的减法运算
* @param v1
* @param v2
* @return 两个参数数学差,以字符串格式返回
*/
public static String subtract(String v1, String v2)
{
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return b1.subtract(b2).toString();
}
/**
* 提供精确的乘法运算。
* @param v1
* @param v2
* @return 两个参数的积
*/
public static double multiply(double v1, double v2)
{
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.multiply(b2).doubleValue();
}
/**
* 提供精确的乘法运算
* @param v1
* @param v2
* @return 两个参数的数学积,以字符串格式返回
*/
public static String multiply(String v1, String v2)
{
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return b1.multiply(b2).toString();
}
/**
* 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到
* 小数点以后10位,以后的数字四舍五入,舍入模式采用ROUND_HALF_EVEN
* @param v1
* @param v2
* @return 两个参数的商
*/
public static double divide(double v1, double v2)
{
return divide(v1, v2, DEFAULT_DIV_SCALE);
}
/**
* 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
* 定精度,以后的数字四舍五入。舍入模式采用ROUND_HALF_EVEN
* @param v1