我正在尝试使用Clojure的update-in函数,但是我似乎不明白为什么我需要传入一个函数?
发布于 2011-01-10 05:52:22
update-in接受一个函数,因此您可以根据旧值更简洁地更新给定位置上的值。例如,而不是:
(assoc-in m [list of keys] (inc (get-in m [list of keys])))你可以这样写:
(update-in m [list of keys] inc)当然,如果新值不依赖于旧值,那么assoc-in就足够了,您不需要使用update-in。
发布于 2011-01-11 13:50:42
我认为简短的答案是,传递给update-in的函数允许您在单个步骤中更新值,而不是3步(查找、计算新值、设置)。
巧合的是,就在今天,我在Howard Lewis Ship的Clojure演示文稿中遇到了update-in的用法:
(def in-str "this is this")
(reduce
(fn [m k] (update-in m [k] #(inc (or % 0))))
{}
(seq in-str))
==> {\space 2, \s 3, \i 3, \h 2, \t 2}每次调用update-in都会将一个字母作为键,在map中查找它,如果找到,则增加字母计数(否则将其设置为1)。reduce从一个空的map {}开始驱动该过程,并使用输入字符串中的连续字符重复应用update-in。结果是字母频率的映射。圆滑的。
注1: clojure.core/frequencies类似,但使用assoc!而不是更新。
注2:您可以将#(inc (或% 0))替换为(fnil inc 0)。从这里:fnil
发布于 2011-01-10 06:54:03
这是一个实际的例子,你可以看到here。
键入以下代码片段(在REPL中):
(def my-map {:useless-key "key"})
;;{:useless-key "key"}
(def my-map (update-in my-map [:yourkey] #(cons 1 %)))
;;{:yourkey (1), :useless-key "key"}请注意,:yourkey是新的。因此传递给lambda的:yourkey的值是null。cons会将1作为列表中的单个元素。现在执行以下操作:
(def my-map (update-in my-map [:yourkey] #(cons 25 %)))
;;{:yourkey (25 1), :useless-key "key"}就是这样,在第二部分中,匿名函数将列表-- :yourkey的值--作为参数,并且只对它使用cons 25。
因为我们的my-map是不可变的,所以update-in将总是返回一个新版本的映射,让您使用给定键的旧值执行某些操作。
希望它能帮上忙!
https://stackoverflow.com/questions/4641964
复制相似问题