这是模拟 C#
BitConverter.ToUInt32(Encoding.UTF8.GetBytes(hash.Substring(i, 4)), 0)
有没有办法在 Javascript 中存档与此类似的内容?
这是模拟 C#
BitConverter.ToUInt32(Encoding.UTF8.GetBytes(hash.Substring(i, 4)), 0)
有没有办法在 Javascript 中存档与此类似的内容?
我认为您可能想从字符串中获取原始字符代码,在这种情况下,您甚至不需要担心 unicode 问题,请记住,javascript 无论如何每个字符都使用两个字节:
var str="✇ƒ";
var br=str.slice(0,2).split("")
       .map(function(a){return ("00000000000000000"+a.charCodeAt().toString(2))
       .slice(-16); })
var lng=parseInt(br.join(""),2);
var andBack = ( "00000000000000000" + lng.toString(2))
  .slice(-32)
  .split(/^(\w{16})/)
  .filter(Boolean)
  .map(function(a){return String.fromCharCode(parseInt(a,2))})
  .join("");
alert([str, br, lng, andBack].join("\n"))
/* shows:
✇ƒ 
0010011100000111,0000000110010010
654770578
✇ƒ     
*/
    不是直接的。简单的位移和添加应该做到这一点:
// data[] contains 4 bytes representing an unsigned integer
// make sure to adjust for endiannes (may need to flip order of indexes)
var result = (data[0]<<24) + (data[1] << 16) + (data[2] << 8) + (data[3]);
请注意,大多数 JavaScript 实现都没有足够的精度来正确保存所有UIint64/Int64值。
function utf8encode( str ) {
    var encoded = unescape(encodeURIComponent(str)),
        ret = new Uint8Array(encoded.length);
    for( var i = 0, len = encoded.length; i < len; ++i ) {
        ret[i] = encoded.charCodeAt(i);
    }
    return ret;    
}
var uint32 = new Uint32Array(utf8encode(hash.substring(i, 4)).buffer)[0];
例如:
var hash = "aosdasokda", i = 0;
uint32将1685286753在小端机器和大端机器  1634693988上。C# BitConverter上也存在同样的不一致,我认为必须重现。
这是模拟BitConverter.isLittleEndian:
function isLittleEndian() {
    var v = new Uint16Array(1),
        r = new Uint8Array(v);
    v[0] = 0xFF00;
    return r[0] === 0x00;
}