内容简介:我想知道如何编写很容易理解它是如何工作的,但是我无法在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
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Game Programming Patterns
Robert Nystrom / Genever Benning / 2014-11-2 / USD 39.95
The biggest challenge facing many game programmers is completing their game. Most game projects fizzle out, overwhelmed by the complexity of their own code. Game Programming Patterns tackles that exac......一起来看看 《Game Programming Patterns》 这本书的介绍吧!