首先对表达式5-3.5==1.5进行分析,该表达式有两个运算符,分别为减号-和关系运算符==,由于减法运算符的优先级高于关系运算符,所以表达式将要输出一个布尔值,即输出false和true。
在java中基本类型的浮点数运算是不精确的,如果在java程序中输出5-1.5的值,可以看到输出的结果是0.40000000000000036,这个值是不精确的,所以表达式的值是假,即false。
@Test
public void test(){
System.out.println(5-4.6);
System.out.println(5-4.6==0.4);
}
我们可以使用BigDecimal进行浮点数的计算
BigDecimal a=new BigDecimal("5");//创建5 的BigDecimal 对象
BigDecimal b=new BigDecimal("4.6");//创建4.6的BigDecimal 对象
BigDecimal c=a.subtract(b);//计算5和4.6的差
double value=c.doubleValue();//将计算结果转换为基本数据类型double型
System.out.println(value);
System.out.println(value==0.4);//输出比较的结果
咋实际应用当中为了得到精确的计算结果,低于浮点数的运算一般不使用基本数据类型来实现,而是使用BigDecimal类来实现,但是在创建BigDecimal对象时,构造方法的参数要用双引号括起来。