我偶然发现了partial
中cojure.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))))
)
我还注意到其他几个函数遵循相同的模式。
答案 0 :(得分:7)
是的,这是性能优化。
我不只是不打电话给concat
- 它是关于参数列表中的&
还需要创建集合的事实。 clojure核心库倾向于认真对待性能,假设语言的基本构建块将出现在每个人的性能瓶颈中。