64 位整数表示

2017-08-04 01:01:14 +08:00
 ghostheaven
需要从 Buffer 里读出来一个 64 位的整数,发现 JS 最大精确的整数< 64 位,所以不提供 readUint64BE 的方法。如果用 bignum 处理就太麻烦,所有相关的四则运算都得改写成函数调用。

幸好 Buffer 里的数字也没有超过 JS 最大的整数值,所以就用 JS 的整数简单代替了一下,一旦发现 Buffer 这个值的高位超过了最大整数的高位就直接报错了事。

大家都是怎么处理这种问题的
3327 次点击
所在节点    Node.js
9 条回复
chai2010
2017-08-04 01:07:14 +08:00
js 里面是 float64,可以精确涵盖 int53 范围的整数,如果够用就用 js 内置的浮点数就行了
ETiV
2017-08-04 01:56:56 +08:00
有个 long.js
可以把 buffer 转成 long 对象,分 high、low,还可以.toString
ghostheaven
2017-08-04 13:47:05 +08:00
@chai2010 是 64 位的偏移量,指向文件内的一个位置,浮点肯定不行。
ghostheaven
2017-08-04 13:51:53 +08:00
@ETiV 这个跟 bignum 的问题一样,要用它的方法代替运算符,不过这可能是 js 上的唯一方式。
不知道 typescript 有没有 64 位的强类型,或者要考虑 webassembly 了。
chai2010
2017-08-04 16:33:29 +08:00
@ghostheaven 30bit 是 1GB, 40bit 是 1TB, 50bit 是 1PB, 指向文件内的一个位置很小的,
int53 足够表示, 这是 double 型能精确表示的整数区域.
8qwe24657913
2017-08-04 20:44:29 +08:00
现在就得改成函数调用;将来的话,有个 stage-3 的提案 https://github.com/tc39/proposal-bigint
ghostheaven
2017-08-05 07:39:08 +08:00
@chai2010 确实,忘记算一下了,暂时用 js 的整数不会出问题。
ghostheaven
2017-08-05 10:23:11 +08:00
@8qwe24657913 这个不知道啥时候能成正式的标准,而且说混合普通数值运算会丢精度,这就有点坑了。
53 位的整数看上去还不错,一般见不到那么大的文件。
8qwe24657913
2017-08-05 16:11:09 +08:00
@ghostheaven #8 仔细看,他说的是因为混合运算会丢精度,所以不允许混合运算,要你手动调用 Number()或 BigInt()来转换类型再运算

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/380293

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX