完全缺乏clojure经验,自大学以来没有任何函数式编程实践,我试图解释一些示例代码来找出clojure语法。
我开始编写几个版本的Fibonacci(https://gist.github.com/pcalcao/ea4176719d778ea3ab9e),但我仍然不能说我完全理解更复杂的形式。
例如,这个:
(defn fib_map [n]
(last (take (+ n 1)
(map first (iterate (fn [[a b]] [b (+ a b)]) [0 1])))))
我很难真正理解这段代码的最内层部分:
fn [[a b]] [b (+ a b)]
现在,根据我的理解,我们正在创建一个匿名函数,它接收一个参数,一个带有两个值的向量(这是解构,对吧?),然后返回另一个向量。
现在,我们这样做的原因是什么,而不是:
fn [a b] [b (+ a b)]
这些是等价的吗?或者我们只是让我们的匿名函数接收一个参数作为{gimmick'在iterate
中使用?
很抱歉,如果这是非常明显的,但就像我说的那样,类似Lisp的语言不是我的强项。
答案 0 :(得分:11)
你已经自己弄清楚了。
(fn [[a b]] ...)
形式的功能正在使用解构。它需要一个参数,它应该是一个向量或另一种支持clojure nth
函数的对象。使用解构,它将前两个值“拉”出向量,并将它们分配给局部变量a
和b
。
(fn [a b] ...)
形式的功能是两个参数的函数。这两者并不相同。
您必须将(fn [[a b]] ...)
表单与iterate
一起使用的原因是iterate
仅适用于单参数函数。
答案 1 :(得分:2)
这是因为iterate只接受两个参数,即一个函数和一个参数。 cf. the docs