2

由于对 clojure 完全没有经验,并且自大学以来没有任何函数式编程实践,我试图解释一些示例代码以找出 clojure 语法。

我首先编写了几个版本的斐波那契 ( 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)]

这些是等价的吗?或者我们只是让我们的匿名函数接收一个参数作为“噱头”来使用iterate

对不起,如果这很明显,但就像我说的,类似 Lisp 的语言还不是我的强项。

4

2 回答 2

11

你已经自己弄清楚了。

表单的功能(fn [[a b]] ...)是使用解构。它需要一个参数,该参数应该是支持 clojurenth功能的向量或其他类型的对象。使用解构,它将前两个值“拉”出向量,并将它们分配给局部变量ab.

函数的形式(fn [a b] ...)是两个参数的函数。两者不等价。

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

于 2013-03-07T13:42:17.717 回答
2

这是因为 iterate 只需要两个参数,即一个函数和一个参数。参看。文档

于 2013-03-07T13:34:01.510 回答