低成本并行与Clojure并发编程解析
1. 低成本并行
在Clojure中,有许多灵活的并发工具,其中之一是 agents ,可用于高效地并行化工作负载。不过,有时我们希望尽可能简单地并行化某些操作。
在深入探讨之前,我们需要区分并发(Concurrency)和并行(Parallelism)的概念:
- 并发 :是指多个通常交错执行的线程对共享状态进行访问或修改的协调过程。
- 并行 :同样涉及状态,但通常是相反的方式。它是一种优化技术,旨在有效利用所有可用资源(通常是计算资源,有时也包括带宽等其他资源)来提高操作性能。并行化方法通常旨在最大化对状态(或状态块)的独占访问窗口,以最小化协调开销。并行操作的多次评估是同时进行的,有时在不同的CPU核心上,有时甚至在不同的物理机器上。
Clojure的 seq 抽象非常灵活,使得基于序列处理实现许多例程变得非常容易。例如,我们可以定义一个函数来查找字符串中的电话号码:
(defn phone-numbers
[string]
(re-seq #"(\d{3})[\.-]?(\d{3})[\.-]?(\d{4})" string))
(phone-numbers " Sunil: 617.555.2937, Betty: 508.555.2218")
;= (["617.555.2937" "617" "555" "2937"] ["508.555.2218" "508" "555" "2
超级会员免费看
订阅专栏 解锁全文
67

被折叠的 条评论
为什么被折叠?



