double类型大小比较的方法

文章介绍了在Java中比较double类型数据的三种方式:1)转换为字符串后用equals比较;2)利用doubleToLongBits()方法转换为long比较;3)设定误差范围判断数值接近程度。这些方法解决了浮点数比较时可能出现的不精确问题。
摘要由CSDN通过智能技术生成

问题

在Java中,int类型数据的大小比较可以使用双等号,double类型则不能使用双等号比较大小,那若使用double类型时怎么进行比较呢?

方法一:

转换为字符串

如果要比较的两个double数据的字符串精度相等,可以将数据转换成string然后借助string的equals方法来间接实现比较两个double数据是否相等。

在这里插入图片描述
代码运行结果如下:

在这里插入图片描述

方法二:

(2)使用doubleToLongBits()方法

该方法可以将double转换成long型数据,从而可以使double按照long的方法(<, >, ==)判断是否大小和是否相等。

在这里插入图片描述
代码运行结果如下:
在这里插入图片描述

方法三:

(3)在误差范围内运行相等

两实数的差在允许范围内认为相等即可认为是相等的。代码中的0.0000001指范围(1e-6)

在这里插入图片描述
代码运行结果如下:

在这里插入图片描述

结语

针对如何在double类型时比较大小的问题,此处我们提供了三种解法,分别为先将它们转换类型变为字符串类型再进行比较,第二种是使用doubleToLongBits()方法,第三种最为简单,则是使其差值在误差范围内则两个值相等。注意第一种转换为字符串类型的方法只适用于比较精度相同的数据,并且只用于两者是否相等的情况下。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值