Clojure矢量作为函数参数

时间:2013-03-07 13:25:19

标签: clojure

完全缺乏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的语言不是我的强项。

2 个答案:

答案 0 :(得分:11)

你已经自己弄清楚了。

(fn [[a b]] ...)形式的功能正在使用解构。它需要一个参数,它应该是一个向量或另一种支持clojure nth函数的对象。使用解构,它将前两个值“拉”出向量,并将它们分配给局部变量ab

(fn [a b] ...)形式的功能是两个参数的函数。这两者并不相同。

您必须将(fn [[a b]] ...)表单与iterate一起使用的原因是iterate仅适用于单参数函数。

答案 1 :(得分:2)

这是因为iterate只接受两个参数,即一个函数和一个参数。 cf. the docs