JavaScript中的整数除法和位移

时间:2013-08-16 20:01:07

标签: javascript endianness bit-shift integer-division

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“/”会将变量转换为浮点变量。所以我使用“&gt;&gt; 8”但这实际上假设了大字节。

1 个答案:

答案 0 :(得分:1)

您提供的代码与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