内容简介:我想知道如何编写很容易理解它是如何工作的,但是我无法在Clojure中重新创建它 – 它不会累积但只返回i的总和和n的初始给定值.关键是incf(在Common Lisp版本中)或=(在JavaScript中).
我想知道如何编写 Revenge of the Nerds 文章中包含的累加器示例.
很容易理解它是如何工作的,但是我无法在Clojure中重新创建它 – 它不会累积但只返回i的总和和n的初始给定值.
关键是incf(在Common Lisp版本中)或=(在JavaScript中).
换句话说:如何改变引用函数的状态?我已经看到了一些关于变量变量的例子,但他们看起来不是 precisely pretty 吗?
不要哎呀!在为时已晚之前保存自己!无缘无故地改变状态不是Clojure所鼓励的,所以当然它不像普通的lisp那样方便.
但严重的是,这是解释闭包的经典示例,虽然它不是Clojure中非常有用的一个,但很高兴知道翻译.你必须写下这样的东西:
(defn foo [n]
(let [acc (atom n)]
(fn [i] (swap! acc + i))))
翻译自:https://stackoverflow.com/questions/8442524/writing-an-accumulator-function-in-clojure
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
C语言算法速查手册
程晓旭、耿鲁静、张海、王勇 / 2009-10 / 49.00元
《C语言算法速查手册》用C语言编写了科研和工程中最常用的166个算法,这些算法包括复数运算、多项式的计算、矩阵运算、线性代数方程组的求解、非线性方程与方程组的求解、代数插值法、数值积分法、常微分方程(组)初值问题的求解、拟合与逼近、特殊函数、极值问题、随机数产生与统计描述、查找、排序、数学变换与滤波等。同时结合这些算法列举了将近100个应用实例,对其进行验证和分析。 《C语言算法速查手册》适......一起来看看 《C语言算法速查手册》 这本书的介绍吧!