17、低成本并行与Clojure并发编程解析

低成本并行与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
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值