我的JavaScript学习之路四:JavaScript数据类型之Number类型(1)

本文探讨了JavaScript中的Number类型,包括数值的精度、范围、数值表示法以及特殊数值如正负零、NaN和Infinity。JavaScript中所有数字以64位浮点数形式存储,存在精度限制,最大值为2的1024次方,最小值为2的-1075次方。科学计数法在特定条件下会被自动使用,特殊数值如正负零在某些场景下有区别,而NaN不等于任何值,包括它自己。
摘要由CSDN通过智能技术生成

计算机是操作数的机器,而且计算机也只能操作数,也只能操作0和1,人类要做的就是把所有的信息都映射为二进制数,把一些问题交给计算机来处理。

一、数值

JavaScript不像其他语言一样有整型、浮点型等数值类型,而是只有一个总称数值类型number。

JavaScript 内部,所有数字都是以64位浮点数形式储存,即使整数也是如此。所以,1与1.0是相同的,是同一个数。

1 === 1.0  //true

JavaScript 语言的底层根本没有整数,所有数字都是小数(64位浮点数)。涉及到整数运算时,JavaScript 会自动把64位浮点数,转成32位整数,然后再进行运算。

浮点数不是精确的值,所以涉及小数的比较和运算要特别小心

0.1 + 0.2 === 0.3  //false
0.1 + 0.2 //  0.30000000000000004
0.3 / 0.1 //  2.9999999999999996

(1) 数值的精度

JavaScript的浮点数并不是IEEE 754标准的完全实现。Java的浮点数实现用的是IEEE 754的一个子集,而JavaScript用的则是该子集的子集,所以JavaScript的number类型与Java的double类型非常相似,都是64位的浮点数类型。

一个number类型包含1位符号位(sign)、11位指数位以及53位有效位数。有些神奇的编码能将65位数据装进64位内存中。

根据国际标准 IEEE 754,JavaScript 浮点数的64个二进制位,从最左边开始,是这样组成的。

  • 第1位:符号位,在64位中的最高位中,0表示正数,1表示负数
  • 第2位到第12位(共11位):指数部分
  • 第13位到第64位(共52位):小数部分(即有效数字),在64位中的最低几位中,通常表示一个范围内的小数

符号位决定一个数的正负,指数部分决定数的大小,有效数字部分决定数的精度

(-1)^符号位 * 1.xx...xx * 2^指数部分

指数部分一共有11个二进制位,因此大小范围就是0到2047。IEEE 754 规定,如果指数部分的值在0到2047之间(不含两个端点),那么有效数字的第一位默认总是1,不保存在64位浮点数之中,称作彩蛋位
也就是说,有效数字这时总是1.xx…xx的形式,其中xx…xx的部分保存在64位浮点数之中,最长可能为52位。因此,JavaScript 提供的有效数字最长为53个二进制位。

精度最多只能到53个二进制位,这意味着,绝对值小于2的53次方的整数,即-253到253,都可以精确表示。 (-253到253)

Math.pow(2, 53)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值