据我所知,步行和地图都适用于seq的功能。 (走路还允许应用一个outer
功能后处理)。然而,使用其中一种的习惯性案例是什么?步行vs地图处理seq
回答
将函数应用于seq是map的工作。当你必须遍历整个结构并递归地遍历整个结构时,请使用walk。
walk
的一些示例可以在ClojureDocs处找到,也可在REPL处获得,例如, (user/clojuredocs clojure.walk/postwalk)
。许多示例都是教学法,可以并且应该在实践中用map
或for
(有时候是reduce
)完成。
walk
的典型用例是当您有一个想要递归处理的嵌套结构时。这可能有用的一些示例是clojure.walk
名称空间本身,例如,看看(source clojure.walk/keywordize-keys)
。 [注意,如果你要处理它反复或随意,使用拉链(或tree-seq
对于一些简单的迭代的情况下)
我想到的另一个例子是解释解析树:
(require '[clojure.walk :as w])
(def t [+ [* [- 6 2] [/ 9 3]] [* 2 [+ 7 8]]])
(w/postwalk #(if (and (coll? %) (fn? (first %))) (apply (first %) (next %)) %) t)
;=> 42
也许
(eval t) ;=> [#<core$_PLUS_ ... ]
糟糕,形式列出,不VEC:如果,例如,用allowed-fn?
等取代fn?
来评估edn表达,而不是调用过于强大EVAL编译有用职责范围:
(def s (w/postwalk #(if (coll? %) (apply list %) %) t))
s ;=> (#<core$_PLUS_ ...)
(eval s) ;=> 42
啊,在这里通知其他使用walk
的 - 递归改变结构从嵌套向量嵌套的列表。
迭代的例子来默想:
(require '[clojure.walk :as w])
(def s1 (range 8))
s1 ;=> (0 1 2 3 4 5 6 7)
(map inc s1)
;=> (1 2 3 4 5 6 7 8)
(w/postwalk #(if (number? %) (inc %) %) s1)
;=> (1 2 3 4 5 6 7 8)
(def s2 (partition 2 s1))
s2 ;=> ((0 1) (2 3) (4 5) (6 7))
(map (partial map inc) s2)
;=> ((1 2) (3 4) (5 6) (7 8))
(w/postwalk #(if (number? %) (inc %) %) s2)
;=> ((1 2) (3 4) (5 6) (7 8))
(def s3 (partition 2 s2))
s3 ;=> ((0 1) (2 3) (4 5) (6 7))
(map (partial map (partial map inc)) s3)
;=> (((1 2) (3 4)) ((5 6) (7 8)))
(w/postwalk #(if (number? %) (inc %) %) s3)
;=> (((1 2) (3 4)) ((5 6) (7 8)))
(def s4 (partition 2 s3))
s4 ;=> ((((0 1) (2 3)) ((4 5) (6 7))))
(map (partial map (partial map (partial map inc))) s4)
;=> ((((1 2) (3 4)) ((5 6) (7 8))))
(w/postwalk #(if (number? %) (inc %) %) s4)
;=> ((((1 2) (3 4)) ((5 6) (7 8))))
为map
语义是基本上是:应用函数集合中的每个项目,并在一个序列懒洋洋地返回结果:
(map inC#{0 1 2}) ;outputs (when realized) (1 2 3)
注意,输入为一组,但输出的是序列。
散步的语义基本上是:使每个项目已取代了inner
功能,用于该产品的价值相同类型的集合,返回应用outer
新收集的结果:
(walk inc identity #{0 1 2}) ;outputs #{1 2 3}
如果您在walk API(http://richhickey.github.com/clojure/clojure.walk-api.html)中查看其他函数的源代码,您可以看到如何进行散步递归(或仅使用其他函数)。
就成语而言,我不确定。但walk
更复杂,因此在不需要walk
提供的语义的情况下,您应该坚持使用map
。
我认为其他答案能更好地说明差异。但+1为你的努力和欣赏! – murtaza52 2013-03-19 09:57:12
- 1. Scala为seq添加元素并处理期货,地图和异步行为
- 2. 并行处理VS串行处理
- 3. Clojure:cons(seq)vs. conj(list)
- 4. 异步处理图像(Django)
- 5. openvswitch在哪里处理TCP seq和ack?
- 6. 处理地图图块
- 7. 全局PreviewKeyDown处理程序vs本地PreviewKeyDown处理程序
- 8. 修改数组的数据与seq并将数组的地址与seq传递给asyncnet处理send`
- 9. 本地vs黄色屏幕vs处理远程错误
- 10. 处理室内GPS地图
- 11. MATLAB vs Visual C++图像处理
- 12. Python vs Matlab在图像处理
- 13. MATLAB vs Simulink在数字图像处理?
- 14. iPhone处理xml vs soap vs JSON vs RESTful
- 15. 处理邮件:rails vs php vs perl vs?
- 16. Xamarin.Forms地图不相处异步等待
- 17. 处理CryptoStream vs处理底层Stream?
- 18. 线程与异步图像处理?
- 19. 地理点vs地点
- 20. Android的处理器运行的异步
- 21. db2 V10.5启用并行处理步骤
- 22. Node.js处理异步
- 23. 异步处理ODP.NET
- 24. Java异步处理
- 25. 处理ajax同步?
- 26. Play 2:play.libs.WS VS异步处理的第三方客户端库
- 27. Android中的处理程序vs异步调用
- 28. 定时器Vs事件:哪一个更适合异步处理?
- 29. 地图视图触摸事件处理
- 30. 线程vs处理程序vs异步任务android中的套接字?
应用功能的序列是map'的'工作。当你不得不遍历整个结构时递归地使用'walk'。 – 2013-03-08 15:00:37
@ A.Webb可以将它作为答案发布。我想将其标记为答复。如果你能指出一些步行的例子,也会很感激。 – murtaza52 2013-03-15 11:36:03
我的不回答你的问题吗? – sethev 2013-03-15 18:19:48