jon*_*rpe 13
这样它就不会破坏 asm.js:
一元+
后跟一个表达式总是一个数字,或者导致抛出。由于这个原因,不幸+
的是,BigInt 需要抛出,而不是与+
Number 对称:否则,以前“类型声明”的 asm.js 代码现在将是多态的。
正如Bergi在评论中强调的那样,这是三个选项中最不坏的一个:
+
BigInt -> BigInt:破坏 asm.js,以及任何其他做出“一元加号”假设的东西;
+
BigInt -> Number:与不允许在 Number 和 BigInt 之间进行隐式转换的设计决策相冲突;或者
+
BigInt -> 错误。
准确地说,他们有三个选择:让它返回 bigint(这打破了 asm.js 和一些开发人员的期望),让它将 bigint 转换为数字(这与原本禁止隐式转换的设计不一致),或者扔。 (3认同)
更多推荐
抛出,错误
发布评论