| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> JavaScript知识库 -> double类型的两个数可以直接比较吗? -> 正文阅读 |
|
[JavaScript知识库]double类型的两个数可以直接比较吗? |
原文链接:double类型(浮点数)是否相等的判断方法_haikuotiankongdong的博客-CSDN博客_double比较是否相等 · 举个例子:
乍一看,觉得肯定是true啊,都是0.01,其实不是,结果是false; ?????????因为无论我们使用哪种编程语言,在哪种编译环境下工作,都要先把源代码翻译成二进制的机器码才能被计算机所识别。 ????????举个简单的例子,在源程序里面2.4,是十进制的,但计算机不能直接识别,要先编译成二进制。 ????????那么问题来了,2.4的二进制并非是精确的2.4,反而是最为接近的二进制表示是2.39999999999999999999。 打印出来a3和b3看看: ?可以看到,这两个double类型的变量,即使看起来觉得是相等的,但是其实并不是的,因为double浮点数存在精度问题,它所表示的是一个精度区间。 这两个double类型的变量表示的只是0.01上下的一个精度区间内的一个数字。 ????????要真正理解,在Java中,float和double都是浮点数,是二进制数值表示的,就可能出现精度缺失问题。所以处理float和double类型数值时,必须注意精度问题。 ` 结论:?
????????因为double类型的表示往往是不精确的(近似表示),double浮点数存在精度问题,它是属于有精度范围的那种,不够精确。 所以, double类型的两个数可以使用<、>,因为比较大于小于,跟精度范围没有关联; 但是不能直接用==、>=、<=比较大小,因为会涉及到具体的精度。 · 拓展:①,关于double和float类型的加减乘除必须使用BigDecimal。 ②,要多去更加理解计算机中浮点数二进制表示会导致精度问题。详情参见:double类型精度丢失问题,以及解决方法_Morning sunshine的博客-CSDN博客 ?③,NaN:?比如说,Double里边的NaN是一个double类型的常量,但是NaN和任何数据用==比较,都是false; 详情参见:Double里边的NaN是什么?_Morning sunshine的博客-CSDN博客 · 最后:????????所以,对于double类型,>、<可以直接进行比较, ????????==、>=、<=这种情况,最好是通过Double.doubleToLongBits()方法将其先转为long类型,然后再去进行比较。 |
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/23 17:20:53- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |