1 语句
js的缺点:
不能正常处理 64 位整数的基本运算,node 作为服务端 js 的实现,于是只能用 53 位的数字运算,整数用 53 位表示,浮点数也是 53 位。
于是如果一个正常的数据库( mysql 、sqlserver 、sqlite...)返回一个稍微大点的常见的 bigint 类型的有符号整数,比如 ~(1<<63) = (1<<63) -1 = 9223372036854775807 ,那么别的语言收到的都是这个数 9223372036854775807 ,但唯独 node 由于先天的残缺收到的值变成了这样:
```
>let bigintFromDB = 9223372036854775807;
>console.log(bigintFromDB);
9223372036854776000
```
看到没,js 把 9223372036854775807 变成了 9223372036854776000 ,最后几位全变 0 了。
由于历史兼容原因,js 的数字运算在语言层面是残缺且无法修复的,现在 cpu 都是 64 位的,64 位的整数正常加减乘除运算是最基本的使用需求。