math.combinatorics的文档指出所有函数都返回惰性序列。
但是,如果我尝试运行包含大量数据的子集,
(last (combinatorics/subsets (range 20)))
;OutOfMemoryError Java heap space clojure.lang.RT.cons (RT.java:559)
我收到 OutOfMemory 错误。
跑步
(last (range))
烧CPU,但不返回错误。
Clojure 似乎并没有像Stack Overflow question 中解释的那样“保持头脑清醒” 。
为什么会发生这种情况以及如何在子集中使用更大的范围?
更新
正如评论所暗示的那样,它似乎适用于某些人的计算机。所以我将发布我的系统配置
我运行 Mac (10.8.3) 并使用Homebrew安装了Clojure (1.5.1) 。
我的Java版本是:
% java -version
java version "1.6.0_45"
Java(TM) SE Runtime Environment (build 1.6.0_45-b06-451-11M4406)
Java HotSpot(TM) 64-Bit Server VM (build 20.45-b01-451, mixed mode)
我没有更改任何默认设置。我还通过删除~/.m2
文件夹重新安装了所有依赖项。
我的项目.clj。
我使用的命令是这个
% lein repl
nREPL server started on port 61774
REPL-y 0.1.10
Clojure 1.5.1
=> (require 'clojure.math.combinatorics)
nil
=> (last (clojure.math.combinatorics/subsets (range 20)))
OutOfMemoryError Java heap space clojure.lang.RT.cons (RT.java:570)
or
OutOfMemoryError Java heap space clojure.math.combinatorics/index-combinations/fn--1148/step--1164 (combinatorics.clj:64)
我在同事的笔记本电脑上测试了这个问题,他也遇到了同样的问题,但他也在 Mac 上。