【发布时间】:2011-09-21 16:07:21
【问题描述】:
我正在学习 Clojure 解决4clojure 中列出的问题。练习之一是使用可变参数创建您自己的 max 函数。
我正在尝试使用 REPL 解决这个简单的问题,我得到了这个解决方案:
(defn my-max
[first & more] (calc-max first more))
(defn calc-max
[m x]
(cond (empty? x) m
(> (first x) m) (calc-max (first x) (rest x))
:else calc-max m (rest x)))
这很好,但练习不允许使用def,因此我必须将这两个功能合二为一。当我用它的代码替换 calc-max 引用时,结果是:
(defn my-max
[first & more]
((fn calc-max
[m x]
(cond (empty? x) m
(> (first x) m) (calc-max (first x) (rest x))
:else calc-max m (rest x)))
first more))
但是这段代码不起作用并返回下一个错误:
user=> (my-max 12 3 4 5 612 3)
java.lang.ClassCastException: java.lang.Integer cannot be cast to clojure.lang.IFn (NO_SOURCE_FILE:0)
我猜这个错误来自于尝试评估 calc-max 函数的结果,我猜这是我的语法错误,但我不知道如何解决它。
【问题讨论】:
-
对于它的价值,我喜欢将我的 4clojure 问题的助手定义为包裹结果的
letfn,最终与分离的defns 具有相同的语义。例如,(letfn [(calc-max [m x] ...)] (fn my-max [first & more] ...))Nowfirst的两个实例在词法上是分开的,不会发生冲突,您不必对任何一个函数进行任何重写。
标签: clojure variadic-functions