javascript数值型只有一种吗

javascript数值型只有一种吗

javascript数值只有一种:浮点类型。JavaScript内部存储数字都是按64位浮点类型存储的,所以在JavaScript中实际上是没有整数类型的。按照JavaScript中的数字格式能够表示的整数范围为“[-2^53 ~ 2^53]”,包含边界值;但需要注意的是,数组索引、位操作符等使用的是基于32位的整数。

本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

在JavaScript中,数值类型只有一种,内部表示为64位浮点数。所以在JavaScript中实际上是没有整数类型的。

print(3/2); // 1.5

可见,数值都是按浮点数来处理的。

因为JavaScript内部存储数字都是按64位浮点类型存储的,无论整数和小数。容易造成混淆的是,某些位运算必须要整数才可以运行,所以会自动将64位浮点数转化为32位整数。再进行位运算。在JavaScript中,1和1.0是一样的

1 == 1.0 true0.1+0.2 == 0.3 false0.3/0.1 = 2.99999999996(0.3-0.2) === (0.2-0.1) false

总之,涉及小数的运算要小心

按照JavaScript中的数字格式(IEEE-754定义的64位浮点格式),能够表示的整数范围为[-2^53 ~ 2^53],包含边界值。然而需要注意的是,数组索引、位操作符等使用的是基于32位的整数。

浮点数值的较高精度是17位小数,但在进行算术计算时其精确度远远不如整数。例如,0.1加0.2的结果不是0.3,而是0.30000000000000004。这个小小的舍入误差会导致无法测试特定的浮点数值。

因为二进制浮点数可以精确地表示1/2、1/8等,但不能精确地表示1/10、1/100等。所以像0.1这样的简单数字也不能精确表示。

由于浮点数有精度问题,可能会在比较时得到一此意想不到的结果:

print((0.1+0.2) == 0.3); // falseprint(0.1+0.2);          // 0.30000000000000004print(0.3);              // 0.3print((10/3-3) == (1/3));// falseprint(10/3-3);           // 0.3333333333333335print(1/3);              // 0.3333333333333333

对于整数的情况,只要使用53位以内的整数,则不会出现精度问题,可以放心使用。

除了以十进制表示外,整数还可以通过八进制(以8为基数)或十六进制(以16为基数)的字面值来表示。其中,八进制字面值的名列前茅位必须是零(0),然后是八进制数字序列(0~7)。如果字面值中的数值超出了范围,那么前导零将被忽略,后面的数值将被当作十进制数值解析。

八进制字面量在严格模式下是无效的,会导致支持该模式的JavaScript引擎抛出错误。

十六进制字面值的前两位必须是0x,后跟任何十六进制数字(0~9及A~F)。其中,字母 A~F 可以大写,也可以小写。

由于保存浮点数值需要的内存空间是保存整数值的两倍,因此ECMAScript会不失时机地将浮点数值转换为整数值。显然,如果小数点后面没有跟任何数字,那么这个数值就可以作为整数值来保存。同样地,如果浮点数值本身表示的就是一个整数(如1.0),那么该值也会被转换为整数。

数值对象

与字符串值对应着一个字符串对象一样,数值也有对应的数值对象,即Number。

数值同样可以直接调用数值对应的属性:

print((6).toString()); // 6

注意,本例中,数值需要添加括号,否则句点会被认为是小数点。

Number的使用与String的使用类似,可以进行类型转换、创建数值对象等。

在进行类型转换时,如果转换不成功,即Number返回NaN,使用数值对象时也是如此。

var a = Number('x');print(typeof a, a);       // number NaNvar b = new Number('x'); print(typeof b, b);       // object [Number: NaN]

Number具有5个特殊属性(只读),即:

  • MAX_VALUE :正数最大值,再大就会变成Infinity

  • MIN_VALUE :正数最小值,再小就会变成0

  • NaN :Not a Number

  • NEGATIVE_INFINITY :负无穷大,即-Infinity

  • POSITIVE_INFINITY :正无穷大,即Infinity

print(Number.MAX_VALUE);         // 1.7976931348623157e+308print(Number.MIN_VALUE);         // 5e-324print(Number.NaN);               // NaNprint(Number.NEGATIVE_INFINITY); // -Infinityprint(Number.POSITIVE_INFINITY); // Infinity

Infinity

当数字运算结果超过了JavaScript所能表示数字上限时,结果为一个特殊的无穷大值(Infinity),如果是负数的值超过了JavaScript所能表示的负数范围,则结果为-Infinity。

当运算结果无限接近于零并比JavaScript能表示的最小值还小的时候(下溢),结果为0,当负数发生下溢时,结果为-0,正数发生下溢,则结果为+0。

JavaScript预定义了全局变量Infinity和NaN,它们都是只读变量。

由于内存的限制,ECMAScript并不能保存世界上所有的数值。ECMAScript能够表示的最小数值保存在Number.MIN_VALUE中——在大多数浏览器中,这个值是5e-324;能够表示的最大数值保存在Number.MAX_VALUE中——在大多数浏览器中,这个值是1.7976931348623157e+308。如果某次计算的结果得到了一个超出JavaScript数值范围的值,那么这个数值将被自动转换成特殊的Infinity值。具体来说,如果这个数值是负数,则会被转换成-Infinity(负无穷),如果这个数值是正数,则会被转换成Infinity(正无穷)。

如果某次计算返回了正或负的Infinity值,那么该值将无法继续参与下一次的计算,因为Infinity不是能够参与计算的数值。要想确定一个数值是不是有穷的(换句话说,是不是位于最小和最大的数值之间),可以使用isFinite()函数。

NaN

NaN是一个特殊的数值,这个数值用于表示一个本来要返回数值的操作数未返回数值的情况(这样就不会抛出错误了)。

对于NaN,要记住的一点是,只要运算中出现NaN,结果就一定是NaN,就算是”NaN*0″这样的运算,也一样是NaN。只要对NaN运行比较运行,结果就一定是false,就算”NaN==NaN”/”NaN!=NaN”等,都是false。

要判断一个值是否为NaN,可以使用isNaN()函数:

print(isNaN(NaN));  // trueprint(isNaN(0/0));  // true

在基于对象调用isNaN()函数时,会首先调用对象的valueOf()方法,然后确定该方法返回的值是否可以转换为数值。如果不能,则基于这个返回值再调用toString()方法,再测试返回值。

也可以使用x!==x来判断x是否为NaN,只有在x为NaN的时候,这个表达式的值才为true。

inFinite()

isFinite函数用于判断一个数是否为“正常”的数值:

print(isFinite(Number.NaN));               // falseprint(isFinite(Number.NEGATIVE_INFINITY)); // falseprint(isFinite(Number.POSITIVE_INFINITY)); // false

除了以上3个特殊值外,其他值的结果都为true

假如x是一个普通数值,则有:

x/0 = Infinityx%0 = NaNx/Infinity = 0x%Infinity = x0/0 = NaN0%0 = NaNInfinity/x = InfinityInfinity%x = NaNInfinity/Infinity = NaNInfinity%Infinity = NaN

完整输出如下:

print(0 / 0);           // NaNprint(3 / 0);           // Infinityprint(Infinity / 0);    // Infinityprint(0 % 0);           // NaNprint(3 % 0);           // NaNprint(Infinity % 0);    // NaN----------print(0 / 4);           // 0print(3 / 4);           // 0.75print(Infinity / 4);    // Infinityprint(0 % 4);           // 0print(3 % 4);           // 3print(Infinity % 4);    // NaN----------print(0 / Infinity);           // 0print(3 / Infinity);           // 0print(Infinity / Infinity);    // NaNprint(0 % Infinity);           // 0print(3 % Infinity);           // 3print(Infinity % Infinity);    // NaN

负零与正零

负零与正零的值相等,不过毕竟带有符号,在一些运算中会有符号方面的差别,比如:

var zero = 0; var negz = -0;

此时,zero 等于 negz , 但1/zero 却不等于 1/negz。

读到这里,这篇“javascript数值型只有一种吗”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注亿速云行业资讯频道。

文章标题:javascript数值型只有一种吗,发布者:亿速云,转载请注明出处:https://worktile.com/kb/p/29155

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
亿速云的头像亿速云认证作者
上一篇 2022年9月24日 上午12:09
下一篇 2022年9月24日 上午12:10

相关推荐

  • mysql索引的查询语句怎么写

    mysql索引的查询语句是“SHOW INDEX”,可以返回与当前数据库或指定数据库中的表关联的索引信息,完整语法“SHOW INDEX FROM 表名 [FROM 数据库名];”;其中,“FROM 数据库名”选项是可选的,省略则返回当前数据库中表关联的索引信息,若不省略则返回指定数据库中表的索引信…

    2022年9月26日
    65000
  • windows KB4525237安装失败怎么解决

    根据情况不同,小编为大家准备了四种解决方案 名列前茅种方案: 重新下载安装补丁 在我们下载补丁的过程中可能就会遇到文件损坏的情况,所以破损的补丁安装包是无法安装成功的。 这种情况下可以尝试重新下载一个补丁安装包重新安装。 第二种方案: 更新升级最新的.net framework(目前是4.8版本) …

    2022年9月1日
    30700
  • 电脑更新错误0x800f0988如何解决

    解决方法: 方法一: 1、首先点击左下角的开始菜单,然后在其中找到“设置” 2、再点击进入设置中的“更新和安全” 3、然后在左侧边栏中选择“疑难解答” 4、然后在右侧启动并运行中点开“windows更新”,选择“运行疑难解答” 5、最后只要等待系统自动检测问题并解决就可以正常更新了。 方法二: 1、…

    2022年9月16日
    75400
  • 如何用transition实现短视频APP的点赞动画

    实现不同表情的不断上升 如果使用纯 CSS 实现这一整套动画的话。我们首先需要实现一段无限循环的,大量不同的表情不断向上漂浮的动画。 像是这样: 这个整体还是比较容易实现的,核心原理就是同一个动画,设置不同的 transition-duration,transition-dalay,和一定范围内的旋…

    2022年9月8日
    42300
  • vue组件值变化但不刷新问题怎么解决

    今天分享文章“vue组件值变化但不刷新问题怎么解决”,主要从:组件值变化但不刷新强制组件刷新、bug复现、解决等几个方面为大家介绍,希望能帮到您。 组件值变化但不刷新强制组件刷新 在调用组件的时候,如果数据中只是某个属性变化(比如id)变化,在vue开发工具中看到变量值变化,但是组件上的数据就是不刷…

    2022年6月29日
    1.9K00
  • C语言怎么实现职工工资管理系统

    一、需求分析 1.随着计算机的飞速发展,它的应用已经十分广泛,它在人们的生产、生活、工作和学习中发挥着重要的作用。例如一个现代化的公司,拥有数千名的员工,那么如何管理这么庞大的职工信息档案呢?这时,开发一个功能完善的职工信息管理系统就必不可少了。 2.从职工的信息的查询到管理实现了自动化的模式,从而…

    2022年8月30日
    43300
  • mysql怎么增加少数索引

    三种增加方法:1、使用“CREATE INDEX”语句增加,语法“CREATE UNIQUE INDEX 索引名 ON 表名(列名列表);”;2、建表时增加,语法“CREATE TABLE 表名(… UNIQUE KEY(列名列表) );”;3、修改表时增加,语法“ALTER TABLE…

    2022年9月22日
    3.0K00
  • word怎么统一调整图片大小

    word图片统一调整大小的方法: 1、首先你需要打开word文档界面,在word插入图片,并选中一张图片。 2、选中图片后,用鼠标右击,这时会弹出下拉菜单,点击“大小和位置”选项。 3、此时会出现“布局”设置窗口,点击大小设置模块。 4、把设置界面中的“锁定纵横比”取消,然后重新设置图片的高度和宽度…

    2022年9月20日
    3.8K00
  • MySQL如何解决delete大量数据后空间不释放的问题

    MySQL 的几种碎片整理方案总结(解决delete大量数据后空间不释放的问题) 1.背景知识? 1.1 为什么会有碎片? MySQL 中 insert 与 update 都可能导致页分裂,这样就存在碎片。 对于大量的UPDATE,也会产生文件碎片化 , Innodb的最小物理存储分配单位是页(pa…

    2022年9月16日
    4.9K00
  • mysql的concat()函数如何用

    在mysql中,concat()函数用于将两个或多个字符串拼接成一个字符串并返回,语法为“CONCAT(string1,string2, … );”;该函数需要至少一个参数,否则会引起错误。concat()函数在拼接之前会将所有参数转换为字符串类型;如果任何参数为NULL,则CONCAT…

    2022年9月21日
    56000
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部