首页  >  问答  >  正文

javascript - js中向下取整

在js中,以前向下取整都是使用Math.floor方法,现在有看到这样的用法:或运算
interval = interval | 0
为什么这样就可以向下取整了,这种用法和Math.floor比较,有什么好处?

PHP中文网PHP中文网2696 天前989

全部回复(5)我来回复

  • 某草草

    某草草2017-06-26 10:57:11

    注意,| 不是逻辑或,而是按位或 (OR)。

    一些小区别。比如 Math.floor(NaN) 还是返回 NaN。但 NaN | 0 返回 0。
    再比如 Math.floor(Infinity) 返回 Infinity,但 Infinity | 0 返回 0

    回复
    0
  • 过去多啦不再A梦

    过去多啦不再A梦2017-06-26 10:57:11

    你还可以这样 interval = interval >> 0

    回复
    0
  • 给我你的怀抱

    给我你的怀抱2017-06-26 10:57:11

    • 首先楼上S1ngS1ng说那些小区别是对的。

    • 另外,|是位或运算,由于0在内存中存储的时候,是所有的整数位全部被填充了0,所以按二进制位和一个数值进行或运算,对应位上无论是0还是10进行或运算,都会得到它本身,但是由于数字0在内存中不存在小数部分,所以位或运算之后interval的小数部分被丢弃。其实是通过丢弃小数部分实现了向下取整。

    • 由于是位运算,所以会比Math.floor()快。

    回复
    0
  • 三叔

    三叔2017-06-26 10:57:11

    真实的原因是:js内部的类型自动转换。

    js的数值都是以64位浮点型表示的。当一个数值需要进行位运算时,js会自动将它转换为32位有符号整形,并舍弃小数部分。

    n|0 ; n>>0 ; //后面的0 仅用于保证n的整数值不变而已。

    从64位降到32位,是会有精度损失的。小心!,最大有效范围: 2^32/2-1

    > f64=(Math.pow( 2,32)/2-1)-0.5
    2147483646.5
    > f64|0
    2147483646
    > f64>>0
    2147483646
    > (f64 + 2)|0 //超出有效范围
    -2147483648
    > (f64 + 2)>>0 //超出有效范围
    -2147483648
    > Math.floor(f64 + 2) //正确
    2147483648

    回复
    0
  • 给我你的怀抱

    给我你的怀抱2017-06-26 10:57:11

    两种都可以实现, interval = interval | 0 这个是一个写作的技巧,看个人爱好吧。可能就是interval = interval | 0这种写法运行会快一点,写代码这个也肯定比Math.floor写得快!

    回复
    0
  • 取消回复