浮点数字取整的方法

1.使用Math.floor()

2.使用位运算符 |

   注意:这种取整方法不适用超过32位整数最大值2147483647的数

   所有位运算符只能用于整数(下面的~也适用),如果是非整数,会先将其转为整数;

   虽然js内部是按照64为浮点数存储,但是位运算的时候是以32位带符号整数进行的.

 function toInt32(x){ 
     return x | 0   // 将不管是整数还是小数转为32位整数
}  
toInt32(Math.pow(2, 32) + 1) // 1
toInt32(Math.pow(2, 32) - 1) // -1
// 对于大于2的32次方的整数,大于32位的数位都会被舍去。
toInt32(
2147483649.4) // -2147483647 js内部采用补码表示负数,减一取反加负号

3. 使用位运算符 ~~(最快的)

  注意: ~NaN = -1; ~~NaN = 0;  所有的值取反后的结果等于 (-1 - 初始值)

4. 使用位运算符 ^

  let i = i ^ 0;

5. 使用位运算符<< 或者 >>

  let i = i << 0;

  let i = i >> 0;

 

测试速度:https://jsperf.com/number-vs-parseint-vs-plus/26

 

 

posted @ 2018-12-05 08:55  Lyra李  阅读(1661)  评论(0编辑  收藏  举报