[英]How do I set up a clojureScript project to use specs and test the clojure.core functions at runtime?
[英]Do I need to do something special to use clojure.core/time?
我正在调用clojure.core / time,记录为“Evaluates expr并打印它所花费的时间。返回expr的值”
例如:
(time (expensive))
宏展开它表明它确实将值存储为let,因此在输出时应该立即返回let表达式中的值。
然而,当我使用昂贵的计算进行呼叫时,我看到延迟然后得到时间,但是必须等待很长时间(有时+10秒或更长时间)才能显示结果。
谁能解释一下这里发生了什么?
PS:这是使用clojure 1.3.0,如果这有任何区别。
也许你正在返回一些懒惰的东西,其中的元素仅在送入REPL时生成? 在这种情况下,您可能希望将其包装在一个迫使所有元素生成的dorun
中。
如果您能提供昂贵计算的详细信息,我们可以看出这是否属实。
来自Savanni D'Gerinel评论的有用补充:
正确的语法可能是(time (doall (computation)))
如果你想返回结果和(time (dorun (computation)))
如果你不想。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.