[英]Integer division and bit shift in JavaScript
是JavaScript代码吗?
var n = 8; // or some arbitrary integer literal
n >> 1;
总是表示“没有剩余的2整数分割”? 如果整数文字大于一个字节,我关心的是endianess。
我的问题的背景如下:
我有一个0到2 ^ 32-1范围内的整数变量,如果我有一个不同于JS的类型化编程语言,它将适合uint32。 我需要将它转换为Uint4Array,其中包含四个以小端顺序排列的元素。
我目前的JavaScript方法是:
function uInt32ToLEByteArray( n ) {
var byteArray = new Uint8Array(4);
for( var i = 0; i < 4; i++ ) {
byteArray[i] = n & 255;
n >> 8;
}
return byteArray;
}
这段代码可以在我的浏览器中运行,但我想知道这是否可以在任何地方使 主要思想是通过取LSB并将divdiding 256来填充数组。但是真正的divions“/”会将变量转换为浮点变量。 所以我使用“>> 8”但这实际上假设了大字节。
您提供的代码绝对与endianess无关。
但是,如果你要重新解释说uint32数组中的字节数组,那么结果会有所不同,具体取决于浏览器运行的机器的字节顺序。
首先,修复代码中的错误:
function uInt32ToLEByteArray(n) {
var byteArray = new Uint8Array(4);
for (var i = 0; i < 4; i++) {
byteArray[i] = n & 255;
n >>>= 8; //simply doing n >> 8 has no effect actually
}
return byteArray;
}
然后
var a = uInt32ToLEByteArray(0xFF)
console.log(a);
//always [255, 0, 0, 0]
var b = new Uint32Array(a.buffer);
console.log(b);
//[255] on little endian machines
//[4278190080] on big endian machines
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.