为什么在clojure.core中实现这样的部分

时间:2015-06-13 12:18:39

标签: clojure

我偶然发现了partialcojure.core函数的实现。它看起来像这样:

(defn partial
  "Takes a function f and fewer than the normal arguments to f, and
  returns a fn that takes a variable number of additional args. When
  called, the returned function calls f with args + additional args."
  {:added "1.0"
   :static true}
  ([f] f)
  ([f arg1]
   (fn [& args] (apply f arg1 args)))
  ([f arg1 arg2]
   (fn [& args] (apply f arg1 arg2 args)))
  ([f arg1 arg2 arg3]
   (fn [& args] (apply f arg1 arg2 arg3 args)))
  ([f arg1 arg2 arg3 & more]
   (fn [& args] (apply f arg1 arg2 arg3 (concat more args)))))

为什么它有几个奇偶校验选项,如果它可以有一个?它只是性能优化所以concat在大多数情况下都不会被调用吗?

我的意思是它看起来像这样,对吧?

(defn partial
  ([f] f)
  ([f & more]
   (fn [& args] (apply f (concat more args))))
  )

我还注意到其他几个函数遵循相同的模式。

1 个答案:

答案 0 :(得分:7)

是的,这是性能优化。

我不只是不打电话给concat - 它是关于参数列表中的&还需要创建集合的事实。 clojure核心库倾向于认真对待性能,假设语言的基本构建块将出现在每个人的性能瓶颈中。