2024 Clojure状态调查!中分享您的想法。

欢迎!请参阅关于页面了解一些关于该功能的信息。

0
ClojureScript

负数的解决方案( https://dev.clojure.org/jira/browse/CLJS-417)会导致浮点数产生讨厌的行为

(mod 2.1 3) ; => 2.0999999999999996

Clojure和标准的JavaScript模运算符此处都返回期望的2.1。

两种可能的解决方案

  • 只有在被除数为负数时才使用双模工作区
  • 检查被除数是否小于除数,如果是,则返回它

9 个答案

0

评论人:dnolen

欢迎补丁。

0

评论人:zto

补丁将 cljs.core/mod 重命名为 double-mod,并在两个参数同号时直接调用 js-mod 来重新定义 mod。
它包括之前失败的测试用例,但我还更全面地测试了与 Clojure 实现的兼容性:https://gist.github.com/aw7/a32bd69923c65bddc23fd63ee062833c

0

评论人:dnolen

非常感谢,你提交了 Clojure CA 吗?

0
by

评论人:zto

是的,两小时前。

0
by

评论者:anmonteiro

小节:不应该将double-mod函数标记为私有吗?

0
by

评论人:zto

我认为没有必要将double-mod作为一个独立的函数存在,我已经添加了一个补丁,将其内联到mod中。

0
by
_评论者:mfikes_

André,ClojureScript需要压缩补丁(CLJS-2319-Fix-cljs.core-mod-handling-of-floats_INLINED.patch中包含了两个补丁)。请参阅https://script.clojure.org/community/patches
0
by

评论者:mfikes

惨了...补丁中某些内容破坏了我们使用Travis运行测试的较旧JavaScriptCore。我唯一想到的可能的原因是额外的mod测试触发了CLJS-910,但这似乎不太可能。

0
by
...