我想在JavaScript中将浮点数转换为整数。实际上,我想知道如何进行两种标准转换:通过截断和舍入。而且高效,而不是通过转换为字符串和解析。
当前回答
按位OR运算符
按位或运算符可用于截断浮点数字,它既适用于正数,也适用于负数:
function float2int (value) {
return value | 0;
}
后果
float2int(3.1) == 3
float2int(-3.1) == -3
float2int(3.9) == 3
float2int(-3.9) == -3
性能比较?
我创建了一个JSPerf测试,用于比较以下各项之间的性能:
数学下限(val)val |0位“或”~~val按位NOTparseInt(val)
这只适用于正数。在这种情况下,可以安全地使用按位运算以及Math.floor函数。
但是如果你需要你的代码同时处理正和负,那么按位操作是最快的(OR是首选)。另一个JSPerf测试与之进行了比较,很明显,由于额外的符号检查,Math现在是四个测试中速度最慢的。
Note
如注释中所述,BITWISE运算符对有符号的32位整数进行运算,因此将转换大数,例如:
1234567890 | 0 => 1234567890
12345678901 | 0 => -539222987
其他回答
您可以使用parseInt方法进行无舍入。由于0x(十六进制)和0(八进制)前缀选项,请小心用户输入。
var intValue = parseInt(floatValue, 10);
编辑:作为警告(来自注释部分),请注意某些数值将被转换为指数形式,如1e21,这将导致“1”的十进制表示不正确
这里有很多建议。按位OR似乎是迄今为止最简单的。下面是另一个简短的解决方案,它也可以使用模运算符处理负数。它可能比按位OR更容易理解:
intval = floatval - floatval%1;
此方法也适用于“|0”、“~~”或“>>0”都不能正常工作的高值数字:
> n=4294967295;
> n|0
-1
> ~~n
-1
> n>>0
-1
> n-n%1
4294967295
在您的例子中,当您希望在末尾插入字符串(以便插入逗号)时,也可以只使用Number.toFixed()函数,但这将执行舍入。
比特移位0,等于除以1
// >> or >>>
2.0 >> 0; // 2
2.0 >>> 0; // 2
对于截断:
var intvalue = Math.floor(value);
对于圆形:
var intvalue = Math.round(value);