【发布时间】:2015-06-11 18:46:51
【问题描述】:
我有一个应用程序,其中服务器每秒向请求它的客户端发送大量数据。在这个数据集中有几个(大)数组,其中包含数字(在某些情况下是 16 位整数,在其他情况下是双精度浮点数)。为了减小数据包大小,我想只发送表示数字所需的字节数(16 位为 2 个字节,64 位为 8 个字节)。我知道我可以这样做:
/* Create space for 4 32 bit numbers */
var buffer = new ArrayBuffer(16);
/* Hex representation of [0, 123, 246, 369] */
buffer = ["0x0", 0x7B", "0xF6", "0x171"];
/* Actual array containing numbers above */
var int32View = new Int32Array(buffer);
但是....我不想在所有内容前面加上“0x”(添加两个字节将使 16 位数字的大小加倍)。我想我可能遗漏了一些东西 - 有没有更好的方法来做到这一点,这样我就不需要指出字符串是数字的十六进制表示(即我可以删除“0x”)吗?
谢谢,马特
【问题讨论】:
-
你是如何传输数据的?作为字符串还是二进制?
-
如果你自己解析它,我想你可以做任何你想做的事情。例如,您可以省略 0x 并查找小数点以确定它是否为浮点数。或者只是在前面加上“x”并寻找它。真的,天空才是极限。
-
["0x0", "0x7B", "0xF6", "0x171"].map(Number) == ["0", "7B", "F6", "171"].map(function(a){return parseInt(a,16);}) -
您将无法从字符串转换浮点数的 64 位表示,因为 JS 没有 64 位整数(yet/es7)。为此,您必须使用 big-int 库(您的示例还用普通数组覆盖类型化数组)。您必须拆分这些值,然后将它们转换为类型化数组。对于浮点数,首先是一个 32 位有符号数组,使用生成的缓冲区作为 Float32 的源(64 位需要特殊处理)。
-
@Pete - 数据作为 JSON 字符串传输。我想最小化数组的大小(即我不想将 5 个字节用于可能表示为 2 的东西)。在服务器端,我可以做的是将数字转换为十六进制表示,但我不想将“0x”附加为 1)这将在计算上很昂贵,并且 2)它会影响传输的数据的大小.
标签: javascript hex typed-arrays