我正在查看Mozilla的代码,该代码向Array添加了一个过滤器方法,并且其中的一行代码使我感到困惑。
var len = this.length >>> 0;
我从未见过>>>在JavaScript中使用过。
这是什么,它做什么?
它不仅将非数字转换为数字,还将其转换为可以表示为32位无符号整数的数字。
虽然JavaScript的数字是双精度浮点(*),位运算符(<<
,>>
,&
,|
和~
)在对32位整数运算的定义。进行按位运算会将数字转换为32位带符号的int,在计算之前,它会丢失所有分数和比32高的位,然后再转换回Number。
因此,进行无实际影响的按位运算(例如,向右移位0位>>0
)是一种舍入数字并确保其在32位int范围内的快速方法。此外,三元>>>
运算符在执行无符号运算后,会将其计算结果转换为Number为无符号整数,而不是其他整数,因此可用于将负数转换为32位二进制补码。版本号很大。使用>>>0
确保您拥有0到0xFFFFFFFF之间的整数。
在这种情况下,这很有用,因为ECMAScript根据32位无符号整数定义了数组索引。因此,如果您尝试以array.filter
与ECMAScript第五版标准完全相同的方式实施,则可以将数字强制转换为32位unsigned
int,如下所示。
(在现实中几乎没有实际的需要这是希望的人是不会被设置array.length
到0.5
,-1
,1e21
或'LEMONS'
。但是,这是我们正在谈论的JavaScript作家,所以你永远不知道…)
摘要:
1>>>0 === 1
-1>>>0 === 0xFFFFFFFF -1>>0 === -1
1.7>>>0 === 1
0x100000002>>>0 === 2
1e21>>>0 === 0xDEA00000 1e21>>0 === -0x21600000
Infinity>>>0 === 0
NaN>>>0 === 0
null>>>0 === 0
'1'>>>0 === 1
'x'>>>0 === 0
Object>>>0 === 0
(*:好吧,它们被定义为像float一样。出于性能原因,如果某个JavaScript引擎实际上在可能的时候使用了int,这也不会令我感到惊讶。但这将是一个实现细节,您无需花任何精力。的优势。)
问题内容: 抱歉,如果已经提出此问题,我已经进行了深入搜索,什么也没有。 现在,我知道: 会将我的价格填充到左侧的零,因此价格为25将得出 00025 如果我想将它们向右填充,结果是 25000 怎么办?我该如何 仅 使用 String.format 模式呢? 问题答案: 您可以使用: 我可以只使用格式模式吗? 就像方法一样使用。从这篇文章中,您将看到输出空间是硬编码的,因此必须使用。
问题内容: 在数组末尾加零的更Python方式是什么? 在我的实际用例中,实际上我想将数组填充到最接近的1024倍数。例如:1342 => 2048,3000 => 3072 问题答案: 使用mode可以满足您的需要,在这里我们可以传递一个元组作为第二个参数来告诉每个大小要填充多少个零,例如a将在左边填充 2个 零,在右边填充 3个 零: 给出为: 也可以通过将元组的元组作为填充宽度来填充2D n
抱歉,如果这个问题已经提出,我已经做了深入的搜索,什么都没有。 现在,我知道: 会在左边用0填充我的价格,所以25的价格会导致00025 如果我想把它们垫在右边,结果是25000呢?如何仅使用String.format模式?
问题内容: 我正在使用DecimalFormat将双精度格式设置为2个小数位,如下所示: 它可以工作,但是如果我有一个像20这样的数字,它就给我这个: 我想要这个: 有什么建议? 问题答案: DecimalFormat类用于将十进制数字值转换为String。在您的示例中,您将使用来自format()方法的String并将其放回double变量中。如果然后输出该double变量,则不会看到格式化的字
在python为什么 我想当时,这应该是正确的。应该给我,但是为什么没有?如果这是对的,为什么当,它给我?
问题内容: 给我数组数据的二进制String表示形式。 但是,我想要一种添加前导零的简单方法,因为等于零的字节数组为我提供了“ 0”字符串。 我想要这样的一线客: 是正确的方法吗?如果是,我应该使用什么字符串?提前致谢! 编辑:数组是动态长度,因此前导零的数目也应如此。 问题答案: 对于使用5个前导零填充,这将起作用: 您没有指定字符串的预期长度,在上面我使用5的示例代码中,将其替换为适当的值。