gpt4 book ai didi

Javascript bitshift 替代 math.round

转载 作者:塔克拉玛干 更新时间:2023-11-02 21:51:29 26 4
gpt4 key购买 nike

var1=anyInteger
var2=anyInteger

(Math.round(var1/var2)*var2)

上面的 JavaScript 移位替代方案的语法是什么?

使用整数而不是 float

谢谢

最佳答案

[更新]快速回答:

var intResult = ((((var1 / var2) + 0.5) << 1) >> 1) * var2;

它比 Math.round() 更快问题中提供的方法并提供完全相同的值。

根据我的测试,位移速度提高了 10% 到 20%。下面是一些比较这两种方法的更新代码。

下面的代码有四个部分:首先,它创建了 10,000 组两个随机整数;其次,它在 OP 的问题中进行循环,存储值以供以后比较并记录总执行时间;第三,它进行等效的位移,存储值供以后比较,并记录执行时间;第四,它比较 Round 和 Bit-shift 值以找出任何差异。它应该报告没有异常。

请注意,这应该适用于所有正的非零值。如果代码遇到分母为零,它将引发错误,而且我很确定负值不会正确移位,尽管我没有测试过。

var arr1 = [],
arr2 = [],
arrFloorValues = [],
arrShiftValues = [],
intFloorTime = 0,
intShiftTime = 0,
mathround = Math.round, // @trinithis's excellent suggestion
i;

// Step one: create random values to compare
for (i = 0; i < 100000; i++) {
arr1.push(Math.round(Math.random() * 1000) + 1);
arr2.push(Math.round(Math.random() * 1000) + 1);
}

// Step two: test speed of Math.round()
var intStartTime = new Date().getTime();
for (i = 0; i < arr1.length; i++) {
arrFloorValues.push(mathround(arr1[i] / arr2[i]) * arr2[i]);
}
console.log("Math.floor(): " + (new Date().getTime() - intStartTime));

// Step three: test speed of bit shift
var intStartTime = new Date().getTime();
for (i = 0; i < arr1.length; i++) {
arrShiftValues.push( ( ( ( (arr1[i] / arr2[i]) + 0.5) << 1 ) >> 1 ) * arr2[i]);

}
console.log("Shifting: " + (new Date().getTime() - intStartTime));

// Step four: confirm that Math.round() and bit-shift produce same values
intMaxAsserts = 100;
for (i = 0; i < arr1.length; i++) {
if (arrShiftValues[i] !== arrFloorValues[i]) {
console.log("failed on",arr1[i],arr2[i],arrFloorValues[i],arrShiftValues[i])
if (intMaxAsserts-- < 0) break;
}
}

关于Javascript bitshift 替代 math.round,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3233731/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com