您的位置 首页 java

Java知识点解析

1.我的第一反应就是为true,因为’-‘的运算等级比’==’高,所以0.4==0.4,

然后就是true,可是这是错的。

2.代码演示:

package Test;

import java.math.BigDecimal;

public class sss {

public static void main(String[] args) {

sss ss = new sss();

ss.ImpreciseResult();

ss.PrecisionResult();

}

public void ImpreciseResult(){

System.out.println(3-2.6);//输出3和2.6的差值

System.out.println(3-2.6==0.4);//输出比较结果

}

public void PrecisionResult(){

BigDecimal x = new BigDecimal(“3”);//创建3的BigDecimal对象

BigDecimal y = new BigDecimal(“2.6”);//创建2.6的BigDecimal对象

BigDecimal z=x.subtract(y);//计算3和2.6的差值

double value=z.doubleValue();//转成double

System.out.println(value);//计算结果

System.out.println(value==0.4);//比较结果

}

}

3.运行结果:

原因是:Java中基本类型的浮点数运算是不精确的,在实际中,为了得到精确的计算结果,对于浮点数的运算一般不使用基本数据类型来实现,而是使用BigDecimal类实现.

文章来源:智云一二三科技

文章标题:Java知识点解析

文章地址:https://www.zhihuclub.com/175780.shtml

关于作者: 智云科技

热门文章

网站地图