《Grokking Concurrency》读后感

一、 为什么读这本书?

1.在工作项目中,有些项目用多线程(如:threading.Thread) , 有些项目用(如:multiprocess.pool), 也有些项目用到协程(如:asyncio)。但是什么时候用哪种技术,自己还不是很了解,从而就无法判断这样用到底好不好,所以想找本书看看,从而梳理清楚。

2.曾经有一个 Python 项目,虽然用了多进程,但是还是出现了请求处理不过来的情况,虽然该项目在后续选择了 Java 技术栈解决了,但这个问题我却始终无法忘记,所以平时留意并发相关的书,看是否能找到解决方案。

因为《Grokking Concurrency》的示例代码使用 Python 语言实现,同时是 2024 年出版的,书中代码不至于无法运行,所以选择阅读该书来了解并发编程。

二、这本书写了什么?

本书主要分为两部分,第一部分介绍了并发的基础:程序,进程,线程,协程;第二部分介绍了并发编程中常遇到的问题:竞态条件,死锁,饥饿等。

本书 304 页,从 2025 年 11 月 10 日至 2025 年 12 月 16 日,期间断断续续花了 23 天阅读完《Grokking Concurrency》。

三、这本书特点

1.重点讲明白了为什么(why)。

这是这本书最大的特点,这本书不是在罗列概念,而是从计算机硬件逐渐展开描述,引入相关的概念。逻辑非常强,读完之后就明白了这个某个概念是什么?为什么要引入这个概念。如我自己平时就很不理解"线程"和"协程"这两个概念,看完之后如醍醐灌顶------要理解线程,要先理解程序的执行原理(program>instruction);而要理解协程则要先理解线程切换需要消耗资源。

2.很多无意义的比喻和插图。

虽然作者想表达:From symphony orchestras to hospital waiting rooms, and from fast food processes to home maintenance, we've drawn comparisons to help you understand complex topics(从交响乐团到医院候诊室,从快餐加工到家庭维修,我们通过类比来帮助理解复杂的主题)。说实话,与其做类比,不如拿实际项目举例。

再者,书中有很多插图,这大概也是该书中文版译名《并发编程图解》 的来源吧。不过,很多图无意义,不是画个图然后配些文字就叫"图解"啊。很多时候之所以需要"图",是因为内容过于抽象,而我们受限于想象力,所以才需要图来帮助理解。话说回来,其实中译版取这个名字也不好,应该叫《深入理解并发编程》。如下面的图就没有什么意义:

3.缺乏实战项目

个人觉得作者确实写得很好,如果能补充一些 syncio 和 aiohttp 在实际项目中的应用就完美了。

四、这本书适合什么样的人?

回到"为什么阅读这本书"。我的第一个问题得到了回答:CPU密集型任务使用多进程,IO密集型使用多线程(阻塞IO)或者协程(非阻塞IO)。但第二个问题本书没有涉及。

本书是一本基础的并发入门书,使用 Python 实现代码。适合想了解并发的 Python 开发者。

五、阅读指数

按照 5 星标准,本书阅读指数 4 颗星(★★★★☆)。

六、参考资料

1. 编程

(1)豆瓣,Kirill Bobrov,《Grokking Concurrency》: https://book.douban.com/subject/36296797/

(2)豆瓣,基里尔·波波洛夫,《并发编程图解》:https://book.douban.com/subject/37364991/

(3)Github,源码: https://github.com/luminousmen/grokking_concurrency

2. 英语

(1) Etymology Dictionary:https://www.etymonline.com

(2) Cambridge Dictionary:https://dictionary.cambridge.org

欢迎搜索及关注:编程人(a_codists)

相关推荐
IVEN_4 小时前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang5 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮6 小时前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling6 小时前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python
AI攻城狮9 小时前
用 Playwright 实现博客一键发布到稀土掘金
python·自动化运维
曲幽9 小时前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
孟健1 天前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python
码路飞1 天前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
曲幽1 天前
FastAPI压力测试实战:Locust模拟真实用户并发及优化建议
python·fastapi·web·locust·asyncio·test·uvicorn·workers